简介
数据库简介
数据库是按照数据结构来组织、存储和管理数据的
RDBMS术语
- 数据库: 数据库是一些关联表的集合
- 数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格
- 列: 一列(数据元素) 包含了相同的数据, 例如邮政编码的数据
- 行:一行(=元组,或记录)是一组相关的数据,例如一条用户订阅的数据
- 冗余:存储两倍数据,冗余降低了性能,但提高了数据的安全性
- 主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据
- 外键:外键用于关联两个表
- 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引
- 索引:使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录
- 参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。与实体完整性是关系模型必须满足的完整性约束条件,目的是保证数据的一致性
管理
安装MySQL
|
|
启动及关闭MySQL服务
|
|
初始化data目录
|
|
连接
cmd命令行连接
在登录成功后会出现 mysql> 命令提示窗口,你可以在上面执行任何 SQL 语句
|
|
退出 mysql> 命令提示窗口可以使用 exit 命令
|
|
创建数据库
登陆 MySQL 服务后,使用 create 命令创建数据库
|
|
普通用户创建数据库
普通用户,需要特定的权限来创建或者删除 MySQL 数据库
|
|
删除数据库
drop 命令删除数据库
删除名为 RUNOOB 的数据库
|
|
普通用户删除数据库
使用 mysql mysqladmin 命令在终端来执行删除命令
|
|
选择数据库
|
|
数据类型
MySQL中定义数据字段的类型对你数据库的优化是非常重要的
MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型
数值类型
整型
- tinyint 0-255 1个字节长
- smallint 0-65535 2个字节长
- int 0-21亿 4个字节长
- bigint 0-42亿 8个字节长
浮点型
- float(M,D) 单精度浮点数。 可以精确到小数点后7位。M代表总宽度,D代表小数位
- double(M,D) 双精度浮点数。可以精确到小数点后15位。M代表总宽度,D代表小数位
日期和时间类型
- date 形如: “YYYY-MM-DD”
- time 形如: “HH:MM:SS”
- datetime 形如: “YYYY-MM-DD HH:MM:SS”
字符串类型
- tinytext 0-255 最小文本型
- text 0-1677万 中型文本
- longtext 0-42亿 大型文本
创建数据表
创建MySQL数据表需要以下信息:
- 表名
- 表字段名
- 定义每个表字段
语法:CREATE TABLE table_name (column_name column_type);
- 不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库时如果输入该字段的数据为NULL ,就会报错
- AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1
- PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔
- ENGINE 设置存储引擎,CHARSET 设置编码
|
|
通过命令提示符创建表
通过 mysql> 命令窗口可以很简单的创建MySQL数据表
|
|
删除数据表
语法:DROP TABLE table_name ;
在命令提示窗口中删除数据表
在mysql>命令提示窗口中删除数据表SQL语句为 DROP TABLE
删除了数据表runoob_tbl
|
|
插入数据
MySQL 表中使用 INSERT INTO SQL语句来插入数据
语法:INSERT INTO table_name ( field1, field2,…fieldN ) VALUES ( value1, value2,…valueN );
通过命令提示窗口插入数据
使用 SQL INSERT INTO 语句向 MySQL 数据表 runoob_tbl 插入数据
|
|

查询数据
语法:SELECT column_name,column_nameFROM table_name[WHERE Clause][LIMIT N][ OFFSET M];
- 查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件
- SELECT 命令可以读取一条或者多条记录
- 使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
- 使用 WHERE 语句来包含任何条件
- 使用 LIMIT 属性来设定返回的记录数
- 通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0
通过命令提示符获取数据
通过 SQL SELECT 命令来获取 MySQL 数据表 runoob_tbl 的所有数据
|
|

WHERE 子句
如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中
|
|
从命令提示符中读取数据
读取 runoob_tbl 表中 runoob_author 字段值为 Sanjay 的所有记录
|
|

MySQL 的 WHERE 子句的字符串比较是不区分大小写的
|
|
UPDATE 查询
修改或更新 MySQL 中的数据,可以使用 SQL UPDATE 命令来操作
|
|
通过命令提示符更新数据
将更新数据表中 runoob_id 为 3 的 runoob_title 字段值
|
|
DELETE 语句
使用 SQL 的 DELETE FROM 命令来删除 MySQL 数据表中的记录
语法:DELETE FROM table_name [WHERE Clause]
从命令行中删除数据
在 SQL DELETE 命令中使用 WHERE 子句来删除 MySQL 数据表 runoob_tbl 所选的数据
|
|
LIKE 子句
“runoob_author = ‘RUNOOB.COM’”,获取 runoob_author 字段含有 “COM” 字符的所有记录,需要在 WHERE 子句中使用 SQL LIKE 子句
|
|
在命令提示符中使用LIKE子句
runoob_tbl 表中获取 runoob_author 字段中以 COM 为结尾的的所有记录
|
|
UNION 操作符
MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合
参数
- expression1, expression2, … expression_n: 要检索的列
- tables: 要检索的数据表
- WHERE conditions: 可选, 检索条件
- DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响
- ALL: 可选,返回所有结果集,包含重复数据
|
|
演示数据库
|
|
SQL UNION 实例
SQL 语句从 “Websites” 和 “apps” 表中选取所有不同的country(只有不同的值)
|
|

SQL UNION ALL 实例
SQL 语句使用 UNION ALL 从 “Websites” 和 “apps” 表中选取所有的country(也有重复的值)
|
|

带有 WHERE 的 SQL UNION ALL
SQL 语句使用 UNION ALL 从 “Websites” 和 “apps” 表中选取所有的中国(CN)的数据(也有重复的值)
|
|

排序
对读取的数据进行排序,我们就可以使用 MySQL 的 ORDER BY 子句来设定你想按哪个字段哪种方式来进行排序,再返回搜索结果
|
|
在命令提示符中使用 ORDER BY 子句
ASC 或 DESC 关键字来设置查询结果是按升序或降序排列
|
|
GROUP BY 语句
GROUP BY 语句根据一个或多个列对结果集进行分组
在分组的列上我们可以使用 COUNT, SUM, AVG,等函数
语法
|
|
实例
使用前我们可以先将以下数据导入数据库中
|
|
导入成功,执行以下 SQL 语句
|
|
使用 GROUP BY 语句
将数据表按名字进行分组,并统计每个人有多少条记录
|
|
使用 WITH ROLLUP
WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…)
|
|
可以使用 coalesce 来设置一个可以取代 NUll 的名称,coalesce 语法
|
|
参数说明:如果a==null,则选择b;如果b==null,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没意义)
|
|
连接的使用
在 SELECT, UPDATE 和 DELETE 语句中使用 Mysql 的 JOIN 来联合多表查询
JOIN按照功能大致分为如下三类
- INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录
- LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录
- RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录
在命令提示符中使用 INNER JOIN
RUNOOB数据库中有两张表 tcount_tbl 和 runoob_tbl
|
|
MySQL的INNER JOIN来连接以上两张表来读取runoob_tbl表中所有runoob_author字段在tcount_tbl表对应的runoob_count字段值
|
|

MySQL LEFT JOIN
MySQL LEFT JOIN 会读取左边数据表的全部数据,即便右边表无对应数据
|
|

MySQL RIGHT JOIN
MySQL RIGHT JOIN 会读取右边数据表的全部数据,即便左边边表无对应数据
|
|

NULL 值处理
SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作
为了处理这种情况,MySQL提供了三大运算符
- IS NULL: 当列的值是 NULL,此运算符返回 true
- IS NOT NULL: 当列的值不为 NULL, 运算符返回 true
- <=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true
在命令提示符中使用 NULL 值
数据库 RUNOOB 中的表 runoob_test_tbl 含有两列 runoob_author 和 runoob_count, runoob_count 中设置插入NULL值
|
|
可以看到 = 和 != 运算符是不起作用的
|
|
查找数据表中 runoob_test_tbl 列是否为 NULL,必须使用 IS NULL 和 IS NOT NULL
|
|
正则表达式
MySQL中使用 REGEXP 操作符来进行正则表达式匹配
- ^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置
- $ 匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置
- . 匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用象 ‘[.\n]’ 的模式
- […] 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’
- [^…] 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’
- p1|p2|p3 匹配 p1 或 p2 或 p3。例如,’z|food’ 能匹配 “z” 或 “food”。’(z|f)ood’ 则匹配 “zood” 或 “food”
- 匹配前面的子表达式零次或多次。例如,zo 能匹配 “z” 以及 “zoo”。 等价于{0,}
- 匹配前面的子表达式一次或多次。例如,’zo+’ 能匹配 “zo” 以及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}
- {n} n 是一个非负整数。匹配确定的 n 次。例如,’o{2}’ 不能匹配 “Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o
- {n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次
|
|
事务
MySQL 事务主要用于处理操作量大,复杂度高的数据
- 在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
- 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
- 事务用来管理 insert,update,delete 语句
事务是必须满足4个条件:原子性、一致性、隔离性、持久性
- 原子性:一个事务中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节
- 一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏
- 隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致
- 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失
事务控制语句
- BEGIN或START TRANSACTION;显式地开启一个事务
- COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改成为永久性的
- ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改
- SAVEPOINT identifier;SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT
- RELEASE SAVEPOINT identifier;删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常
- ROLLBACK TO identifier;把事务回滚到标记点
- SET TRANSACTION;用来设置事务的隔离级别
MYSQL 事务处理主要有两种方法
用 BEGIN, ROLLBACK, COMMIT来实现
- BEGIN 开始一个事务
- ROLLBACK 事务回滚
- COMMIT 事务确认
直接用 SET 来改变 MySQL 的自动提交模式
- SET AUTOCOMMIT=0 禁止自动提交
- SET AUTOCOMMIT=1 开启自动提交
|
|
ALTER命令
修改数据表名或者修改数据表字段时,就需要使用到MySQL ALTER命令
|
|
删除,添加或修改表字段
|
|
修改字段类型及名称
需要修改字段类型及名称, 你可以在ALTER命令中使用 MODIFY 或 CHANGE 子句
|
|
ALTER TABLE 对 Null 值和默认值的影响
当你修改字段时,你可以指定是否包含值或者是否设置默认值
|
|
修改字段默认值
可以使用 ALTER 来修改字段的默认值
|
|
使用 ALTER 命令及 DROP子句来删除字段的默认值
|
|
修改数据表类型,可以使用 ALTER 命令及 TYPE 子句来完成。表 testalter_tbl 的类型修改为 MYISAM
|
|
修改表名
修改数据表的名称,可以在 ALTER TABLE 语句中使用 RENAME 子句来实现
|
|
索引
索引分单列索引和组合索引
单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引
组合索引,即一个索引包含多个列
普通索引
这是最基本的索引,它没有任何限制。
|
|
唯一索引
索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一
|
|
使用ALTER 命令添加和删除索引
- ALTER TABLE tbl_name ADD PRIMARY KEY (column_list): 该语句添加一个主键,这意味着索引值必须是唯一的,且不能为NULL
- ALTER TABLE tbl_name ADD UNIQUE index_name (column_list): 这条语句创建索引的值必须是唯一的
- ALTER TABLE tbl_name ADD INDEX index_name (column_list): 添加普通索引,索引值可出现多次
- ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list):该语句指定了索引为 FULLTEXT ,用于全文索引
|
|
使用 ALTER 命令添加和删除主键
|
|
显示索引信息
SHOW INDEX 命令来列出表中的相关的索引信息。可以通过添加 \G 来格式化输出信息
|
|
临时表
MySQL临时表只在当前连接可见,如果你使用PHP脚本来创建MySQL临时表,那每当PHP脚本执行完成后,该临时表也会自动销毁
使用MySQL 临时表的简单实例,以下的SQL代码可以适用于PHP脚本的mysql_query()函数
|
|
删除MySQL 临时表
可以在当前MySQL会话使用 DROP TABLE 命令来手动删除临时表
|
|
复制表
- 使用 SHOW CREATE TABLE 命令获取创建数据表(CREATE TABLE) 语句,该语句包含了原数据表的结构,索引等
- 复制以下命令显示的SQL语句,修改数据表名,并执行SQL语句,通过以上命令 将完全的复制数据表结构
- 如果你想复制表的内容,你就可以使用 INSERT INTO … SELECT 语句来实现
获取数据表的完整结构
|
|
修改SQL语句的数据表名,并执行SQL语句
|
|
执行完第二步骤后,你将在数据库中创建新的克隆表 clone_tbl。
拷贝数据表的数据你可以使用 INSERT INTO… SELECT 语句来实现
|
|
元数据
- 查询结果信息: SELECT, UPDATE 或 DELETE语句影响的记录数
- 数据库和数据表的信息: 包含了数据库及数据表的结构信息
- MySQL服务器信息: 包含了数据库服务器的当前状态,版本号等
获取查询语句影响的记录数
在 DBI 脚本中, 语句影响的记录数通过函数 do( ) 或 execute( )返回
|
|
在PHP中,你可以使用 mysqli_affected_rows( ) 函数来获取查询语句影响的记录数
|
|
数据库和数据表列表
在MySQL服务器中获取数据库和数据表列表。 如果你没有足够的权限,结果将返回 null
使用 SHOW TABLES 或 SHOW DATABASES 语句来获取数据库和数据表列表
|
|
输出 MySQL 服务器上的所有数据库
|
|
获取服务器元数据
在 MySQL 的命令提示符使用,也可以在脚本中 使用,如PHP脚本
|
|
序列使用
MySQL序列是一组整数:1, 2, 3, …,由于一张数据表只能有一个字段自增主键
使用AUTO_INCREMENT
|
|
获取AUTO_INCREMENT值
使用 mysql_insertid 属性来获取 AUTO_INCREMENT 的值
|
|
PHP 通过 mysql_insert_id ()函数来获取执行的插入SQL语句中 AUTO_INCREMENT列的值
|
|
重置序列
删除了数据表中的多条记录,对剩下数据的AUTO_INCREMENT列进行重新排列,可以通过删除自增的列,重新添加来实现
|
|
设置序列的开始值
序列的开始值为1,需要指定一个开始值100,通过以下语句
|
|
或者你也可以在表创建成功后,通过以下语句来实现
|
|