MySQL(一)MySQL基础介绍

Peter20 等级 961 0 0

最近的学习内容是数据库相关的一些知识,主要以MySQL为主,参考书籍——《MySQL必知必会》

MySQL学习及下载地址:https://dev.mysql.com/

MySQL学习使用注意事项:

1、必须访问一个已有的MySQL服务器,需要一个服务器账号(一个登录名和一个口令)

2、MySQL运行在所有主要平台上,包括Windows、Linux、Solaris、Mac OSX等

3、一个客户机软件(用来实际运行MySQL命令的程序),最容易得到的是mysql命令行实用程序(包含在每个MySQL安装中)

4、安装MySQL时都会提示重要信息,比如安装位置(默认)、root用户口令、端口、服务或进程名等,都可以使用默认值

5、多个MySQL服务器副本可安装于统一机器上,只要每个服务器使用不同的端口即可

一、数据库基础

1、数据库

数据库(database):一个以某种有组织的方式存储的数据集合,保存有组织的数据的容器(通常是一个文件或一组文件)

数据库管理系统(DBMS:database message system):数据库是通过DBMS创建和操作的容器

2、表

表(table):某种特定类型数据的结构化清单

表是一种结构化文件,可用来存储某种特定类型的数据

数据库中每个表都有唯一的一个名字,用来标识自己,表名的唯一性取决于多个因素:如数据库名等结合(相同数据库不能出现名字相同的表,但不同数据库可以使用相同的表名)

表具有一些特性,其定义了数据在表中如何存储,比如:存储什么类型的数据,数据如何分解,各部分信息如何命名等

描述表的这组信息可以称为“模式”,其用来描述数据库中特定的表以及整个数据库(和其中表的关系)

模式(schema):关于数据库和表的布局及特性的信息,一般指给予表的一些定义

3、列和数据类型

表由列组成,列中存储着表中某部分的信息

列(column):表中的一个字段;所有表都有由一个或多个列组成的

分解数据:正确的将数据分解为多个列极为重要:例如省市县应该是独立的列,通过分解,才可能利用特定的列对数据进行排序和过滤,使得检索和访问更加方便(例如找出特定市县的相关数据等)

数据类型(datatype):所容许的数据的类型:数据库中每个列都有相应的数据类型,其定义列可存储的数据种类(限制/容许该列中存储的数据)

作用:①限制可存储在列中的数据种类(例如防止在数值字段中录入字符值)

②帮助正确的排序数据

③对优化磁盘使用有重要作用

4、行

行(row):表中的一个记录

表中的数据是按行存储的,保存的每个记录存储在自己的行内;如果将表想象为网格,网格中垂直的列为表列,水平行为表行

5、主键

主键(primary key):一列或一组列,其值能够唯一区分表中的每一行;唯一标识表中每行的这个列(或这组列)称为主键

主键用来表示一个特定的行;没有主键,更新或删除表中特定行很困难,因为没有安全的方法保证操作只涉及相关的行

主键并不总是需要,但大多数情况下都应保证每个表具有一个主键,以便于数据操作和管理

表中任何列都可以作为主键,只要满足以下2个条件:

任意两行都不具有相同的主键值;

每个行都必须具有一个主键值(主键列不允许NULL值);

主键值规则:主键通常定义于表的一列上,但也可以一起使用多个列作为主键,这种情况下,上述2个条件必须应用到构成主键的所有列,所有列值的组合必须是唯一的(单个列可以不唯一)

设置主键的几个好习惯:

不更新主键列中的值;

不重用主键列的值;

不在主键中使用可能会更改的值(例如使用电话号码作为主键以标识某个人,当该人更改电话号码时,必须更改这个键)

二、SQL简介

SQL:结构化查询语言(Structured Query Language)缩写,一种专门用来与数据库通信的语言

设计SQL的目的是很好的完成一项任务,即提供一种从数据库中读写数据的简单有效的方法

优点如下:

几乎所有的DBMS都支持SQL

SQL简单易学,语句由描述性很强的英语单词构成,而且单词的数目并不多

一门强有力的语言,灵活使用其语言元素,可进行非常复杂和高级的数据库操作

三、MySQL简介

MySQL是一种DBMS,即它是一种数据库软件

MySQL优点:

成本低,MySQL开放源代码,一般都可以免费使用甚至免费修改

性能好,MySQL执行效率很快

很多大型公司(包括一些全世界知名的互联网企业)使用MySQL来处理自己的重要数据

简安装使用非常容易

1、客户机-服务器软件

DBMS可分为两类:一类为基于共享文件系统的DBMS(包括诸如Microsoft和FileMaker),用于桌面用途,通常不用于高端或更关键的应用;一类为基于客户机-服务器的DBMS

常见的例如MySQL、Oracle、Microsoft SQL Server等数据库是基于客户机-服务器的数据库,分为2个部分:

服务器部分是负责所有数据访问和处理的一个软件,该软件运行在称为数据库服务器的计算机上;关于数据增删改查的所有请求都由服务器软件完成,这些请求来自客户机软件的计算机

客户机部分是与用户打交道的软件,由客户机软件通过网络提交请求给服务器软件,服务器软件根据需要处理数据,然后将结果返回给客户机软件

服务器软件为MySQL DBMS,可在本地安装的副本上运行,也可以连接到运行在你具有访问权的远程服务器上的一个副本

客户机可以是MySQL提供的工具、脚本语言(如Perl)、Web应用开发语言(如ASP、ColdFusion、JSP和PHP)、程序设计语言(如Java、C、C++)等

2、MySQL工具

MySQL是一个客户机-服务器DBMS,使用它需要一个客户机,即用来与MySQL打交道(给MySQL提供需要执行的命令)的应用;最好使用专门用途的实用程序,推荐如下三个:

①MySQL命令行实用程序

该程序是安装MySQL时自带的一个简单命令行实用程序;没有下拉菜单、用户界面、鼠标支持或其他支持的东西,但最好熟悉它,因为它是使用者安全依靠的一个客户机

②MySQL Adiministrator

MySQL Adiministrator(MySQL管理器)是一个图形交互客户机,用来简化MySQL服务器的管理

下载地址:http://dev.mysql.com/downloads/

③MySQL Query Browser

MySQL Query Browser(MySQL查询浏览器)是一个图形交互客户机,用来编写和执行MySQL命令

下载地址:http://dev.mysql.com/downloads/

四、连接MySQL及简单操作

连接MySQL数据库需要以下这些条件:

①主机名(计算机名):如果是本地MySQL服务器,为localhost

②端口:如果使用默认端口,则为3306

③一个合法的用户名

④用户口令:即登陆密码(如果需要)

1、选择数据库

安装并且成功连接数据库之后,需要选择一个数据库,如果使用的是命令行实用程序,则可以使用user关键字(比如:user tables;)

关键字(key word):MySQL语言组成部分的保留字,决不能用关键字命名一个表或列

2、了解数据库和表

数据库、表、列、用户以及权限等信息被存储在数据库和表中,内部表一般不直接访问,可以使用show命令来显示(比如:show tablebases;)

show tablebases;返回可用数据库的一个列表

show tables;返回当前选择的数据库内可用表的列表

show也可用来显示表列,比如:show columns from tables

自动增量:某些表列需要唯一值,例如:顾客ID,在每行添加到表中时,MySQL可以自动为每行分配下一个可用编号,不用手动分配,这个功能就是自动增量

如果需要该功能,则需要在用create语句创建表时把它作为表定义的组成部分

其他常见show语句还有:

show status:用于显示广泛的服务器状态信息

show create database 和show create table:分别用来显示创建特定数据库或表的MySQL语句

show grants:用于显示授予用户(所有用户或特定用户)的安全权限

show errors和show warnings:用于显示服务器错误或警告消息

本文转自 https://www.cnblogs.com/imyalost/p/6362054.html,如有侵权,请联系删除。

收藏
评论区

相关推荐

postgresql和mysql哪个好
postgresql和mysql都是免费且功能强大的开源数据库,很多用户面对这两个库都会有一个问题,那就是哪一个才是最好的开源数据库,MySQL还是PostgreSQL呢?该选择哪一个开源数据库呢? postgresql和mysql哪个好 一.PostgreSQL相对于MySQL的优势 1、在SQL的标准实现上要比MySQL完善,而且功能实现比较严谨;
Mysql Workbench使用教程
<1 MySQL WorkbenchMySQL Workbench 为数据库管理员、程序开发者和系统规划师提供可视化的Sql开发、数据库建模、以及数据库管理功能。 <2.MySQL Workbench 的下载和安装 (1)安装最新MySql时,有是否安装MySql Workbench的选项,可选择安装。 (2)可以独立安装MySql Workbench。
一文读懂一条 SQL 查询语句是如何执行的
2001 年 MySQL 发布 3.23 版本,自此便开始获得广泛应用,随着不断地升级迭代,至今 MySQL 已经走过了 20 个年头。为了充分发挥 MySQL 的性能并顺利地使用,就必须正确理解其设计思想,因此,了解 MySQL 的逻辑架构是必要的。本文将通过一条 SQL 查询语句的具体执行过程来详细介绍 MySQL 架构中的各个组件。MySQL 逻辑架构
SQL注入速查笔记
SQL 注入分类方式: 提交方式:GET POST COOKIE ### **0x01 Mysql** * * * ### Mysql划分:权限  root        普通用户 版本  mysql>5.0   mysql<5.0 **1.1 root权限** lo
MySQL——性能优化
性能优化的思路 1、首先需要使用慢查询功能,去获取所有查询时间比较长的SQL语句。 MySQL——慢查询 2、其次使用explain命令去查看有问题的SQL的执行计划。 MySQL——执行计划EXPLAIN 3、最后可以使用show profile\[s\] 查看有问题的SQL的性能使用情况。 MySQL高级:show profile
MySQL数据库优化技巧
MySQL优化三大方向 ① 优化MySQL所在服务器内核(此优化一般由运维人员完成)。 ② 对MySQL配置参数进行优化(my.cnf)此优化需要进行压力测试来进行参数调整。 ③ 对SQL语句以及表优化。 MySQL参数优化 1:MySQL 默认的最大连接数为 100,可以在 mysql 客户端使用以下命令查看 mysql>
MySQL系列(一)
**一、简介** -------- MySQL是最流行的开放源码SQL数据库管理系统,它是由MySQL AB公司开发、发布并支持的。有以下特点: MySQL是一种数据库管理系统。 MySQL是一种关联数据库管理系统。 MySQL软件是一种开放源码软件。 MySQL数据库服务器具有快速、可靠和易于使用的特点。 MySQL服务器工作在客户端/服务器模
MySQL高级
1mysql的架构介绍 Mysql简介 概述 高级MySQL mysql内核 sql优化工程师 mysql服务器的优化 查询语句优化 主重复制 软硬件升级 容灾备份 sql编程 MysqlLinux版本的安装--mysql5.5 查看MySQL的安装位置:which mysqld 参考网址:https://ww
Mysql 初始数据库
Mysql是基于C/S端的服务器软件   Mysql服务端   --server端开启   --解析指令   --对文件夹,文件,数据的增删改查   Mysql客户端   --连接S端   --发送指令(sql语句) **一.安装mysql**   数据库服务器(一台电脑)   数据库管理系统(Mysql软件)   数据库(data/d
mysql,基础命令
一  配置文件 \[mysqld\] \# 设置mysql的安装目录 \*\*后面的路径一定是安装sql的目录(自己电脑的)\*\* basedir=C:\\mysql-5.7.22-winx64\\mysql-5.7.22-winx64 \# 设置mysql数据库的数据的存放目录,必须是data datadir=C:\\mysql-5.7
mysql企业实战(一)
一、简介 ---- MySQL是最流行的开放源码SQL数据库管理系统,它是由MySQL AB公司开发、发布并支持的。有以下特点: * MySQL是一种数据库管理系统。 * MySQL是一种关联数据库管理系统。 * MySQL软件是一种开放源码软件。 * MySQL数据库服务器具有快速、可靠和易于使用的特点。 * MySQL服务器工作在
JMeter 如何与 MySQL 进行整合测试
做性能测试定位瓶颈的时候,定位到是因为某些 SQL 语句的查询慢所影响的,此时我们提出优化方案,肯定希望验证下优化后的 SQL,此时需要借助 JMeter 的 JDBC 请求,那么我们就需要学习 JMeter 如何与 MySQL 进行整合测试。 ### 环境准备 除了 JMeter 外,还需要准备以下软件和 Jar 包: * MySQL 数据库服务
Linux系统Mysql备份的导入导出
Mysql 备份 =========== 如果您使用的是帮助中心的一键环境配置,mysql的安装目录是/alidata/server/mysql,如果您将mysql安装到其他目录,您需要输入您mysql完整的安装路径。 单库备份您可以在服务器上执行/alidata/server/mysql/bin/mysqldump -uroot -p密码 数据库
SQL Server 迁移数据到MySQL
SQL Server 迁移数据到MySQL **一、****背景** 由于要在sqlserver中导出一些报表还要对一些表进行一些特殊处理,好久没用功sqlserver了,想着导入到mysql中更好操作些,所以需要把SQL Server的数据转移到MySQL;由于涉及的表比较多,所以想在MySQL中生成对应表并导入数据; 上网找了些资料,如:[将AC
SQL Server 迁移数据到MySQL
SQL Server 迁移数据到MySQL **一、****背景** 由于要在sqlserver中导出一些报表还要对一些表进行一些特殊处理,好久没用功sqlserver了,想着导入到mysql中更好操作些,所以需要把SQL Server的数据转移到MySQL;由于涉及的表比较多,所以想在MySQL中生成对应表并导入数据; 上网找了些资料,如:[将AC