一些 MySQL 的学习笔记。
数据库的基本概念
一、什么是数据库?
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。
每个数据库都有一个或多个不同的 API 用于创建,访问,管理,搜索和复制所保存的数据。
我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。
所以,现在我们使用**关系型数据库管理系统(RDBMS)**来存储和管理大数据量。
关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。
RDBMS 即关系数据库管理系统的特点:
-
- 数据以表格的形式出现
-
- 每行为各种记录名称
-
- 每列为记录名称所对应的数据域
-
- 许多的行和列组成一张表单
-
- 若干的表单组成 database
二、RDBMS 术语
- 数据库: 数据库是一些关联表的集合。
- 数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。
- 列: 一列 (数据元素) 包含了相同类型的数据, 例如邮政编码的数据。
- **行:**一行(=元组,或记录)是一组相关的数据,例如一条用户订阅的数据。
- 冗余:存储两倍数据,冗余降低了性能,但提高了数据的安全性。
- 主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。
- **外键:**外键用于关联两个表。
- 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引。
- **索引:**使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录。
- 参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。与实体完整性是关系模型必须满足的完整性约束条件,目的是保证数据的一致性。
MySQL 的安装
Ubuntu 系统直接使用 apt 命令安装即可:
sudo apt install mysql-server
验证 MySQL 的安装:
mysqladmin --version
终端上该命令将输出以下结果,该结果基于系统信息:
mysqladmin Ver 8.23 Distrib 5.0.9-0, for redhat-linux-gnu on i386
MySQL 默认的 root 用户密码为空,使用以下命令创建用户密码:
mysqladmin -u root password "newpassword";
创建密码后使用以下命令连接 MySQL 数据库:
mysql -u root -p
newpassword
MySQL 的管理
Ubuntu 系统下:
检查 MySQL 服务是否启动:
ps -ef | grep mysqld
如果 MySql 已经启动,以上命令将输出 mysql 进程列表。
如果 mysql 未启动,可以使用以下命令来启动 mysql 服务器:
cd /usr/bin
./mysqld_safe &
若要关闭目前运行的 MySQL 服务器, 可以执行以下命令:
cd /usr/bin
./mysqladmin -u root -p shutdown
MySQL 用户设置
添加 MySQL 用户,只需要在 MySQL 数据库中的 user 表添加新用户即可。
use mysql;
INSERT INTO user(host,ser,password,select_priv,insert_priv,update_priv) VALUES('localhost','guest',MD5('guest123'),'Y','Y','Y');
FLUSH PRIVILEGES;
添加用户时,使用 MySQL 提供的 MD 5 () 函数来对密码进行加密。
执行 FLUSH PRIVILEGES 语句后会重新载入授权表。
如果不使用该命令,就无法使用新创建的用户来连接 mysql 服务器,除非重启 mysql 服务器。
可以在创建用户时,为用户指定权限,在对应的权限列中,在插入语句中设置为 ‘Y’ 即可,用户权限列表如下:
- Select_priv
- Insert_priv
- Update_priv
- Delete_priv
- Create_priv
- Drop_priv
- Reload_priv
- Shutdown_priv
- Process_priv
- File_priv
- Grant_priv
- References_priv
- Index_priv
- Alter_priv
管理 MySQL 的常用命令
USE DB_NAME :
选择要操作的 Mysql 数据库,使用该命令后所有 Mysql 命令都只针对该数据库。
use RUNOOB;
SHOW DB_NAME:
列出 MySQL 数据库管理系统的数据库列表。
show databases;
SHOW TABLES:
显示指定数据库的所有表,使用该命令前需要使用 use 命令来选择要操作的数据库。
show tables;
SHOW COLUMNS FROM TB_NAME:
显示数据表的属性,属性类型,主键信息,是否为 NULL,默认值等其他信息。
show columns from tb_name;
SHOW INDEX FROM TB_NAME:
显示数据表的详细索引信息,包括 PRIMARY KEY(主键)。
show index from tb_name;
SHOW TABLE STATUS [FROM DB_NAME] [LIKE ‘TB_NAME’] \G:
该命令将输出 Mysql 数据库管理系统的性能及统计信息。
show table status from db_name like 'tb_name'\G;
参数 \G 表示结果按列打印。
MySQL 的数据类型
MySQL 支持多种类型,大致可以分为三类:数值、日期/时间和字符串 (字符) 类型。
一、数值类型
包括严格数值数据类型 (INTEGER、SMALLINT、DECIMAL 和 NUMERIC),
以及近似数值数据类型 (FLOAT、REAL 和 DOUBLE PRECISION)。
类型 | 大小 | 范围(有符号) | 范围(无符号) | 用途 |
---|---|---|---|---|
TINYINT | 1 Bytes | (-128,127) | (0,255) | 小整数值 |
SMALLINT | 2 Bytes | (-32 768,32 767) | (0,65 535) | 大整数值 |
MEDIUMINT | 3 Bytes | (-8 388 608,8 388 607) | (0,16 777 215) | 大整数值 |
INT 或 INTEGER | 4 Bytes | (-2 147 483 648,2 147 483 647) | (0,4 294 967 295) | 大整数值 |
BIGINT | 8 Bytes | (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) | (0,18 446 744 073 709 551 615) | 极大整数值 |
FLOAT | 4 Bytes | (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) | 0,(1.175 494 351 E-38,3.402 823 466 E+38) | 单精度浮点数值 |
DOUBLE | 8 Bytes | (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 双精度浮点数值 |
DECIMAL | 对 DECIMAL (M, D) ,如果 M>D,为 M+2 否则为 D+2 | 依赖于 M 和 D 的值 | 依赖于 M 和 D 的值 | 小数值 |
二、日期和时间类型
表示时间值的日期和时间类型为 DATETIME、DATE、TIMESTAMP、TIME 和 YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的 MySQL 不能表示的值时使用"零"值。
类型 | 大小 ( bytes) | 范围 | 格式 | 用途 |
---|---|---|---|---|
DATE | 3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | 日期值 |
TIME | 3 | ‘-838:59:59’/‘838:59:59’ | HH:MM: SS | 时间值或持续时间 |
YEAR | 1 | 1901/2155 | YYYY | 年份值 |
DATETIME | 8 | 1000-01-01 00:00:00/9999-12-31 23:59:59 | YYYY-MM-DD HH:MM: SS | 混合日期和时间值 |
TIMESTAMP | 4 | 1970-01-01 00:00:00/2038 结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038 年 1 月 19 日凌晨 03:14:07 | YYYYMMDD HHMMSS | 混合日期和时间值,时间戳 |
三、字符串类型
字符串类型指 CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM 和 SET。
类型 | 大小 | 用途 |
---|---|---|
CHAR | 0-255 bytes | 定长字符串 |
VARCHAR | 0-65535 bytes | 变长字符串 |
TINYBLOB | 0-255 bytes | 不超过 255 个字符的二进制字符串 |
TINYTEXT | 0-255 bytes | 短文本字符串 |
BLOB | 0-65 535 bytes | 二进制形式的长文本数据 |
TEXT | 0-65 535 bytes | 长文本数据 |
MEDIUMBLOB | 0-16 777 215 bytes | 二进制形式的中等长度文本数据 |
MEDIUMTEXT | 0-16 777 215 bytes | 中等长度文本数据 |
LONGBLOB | 0-4 294 967 295 bytes | 二进制形式的极大文本数据 |
LONGTEXT | 0-4 294 967 295 bytes | 极大文本数据 |
MySQL 的基本操作
一、连接 MySQL 数据库
Ubuntu 终端下使用以下命令连接 MySQL 数据库:
MYSQL -U USER_NAME -P
mysql -u root -p
回车后输入密码即可。
二、创建 MySQL 数据库
使用 root 账号登陆,即拥有最高权限,即可使用以下命令创建新的 MySQL 数据库:
CREATE DATABASE DB_NAME:
create database db_name;
MYSQLADMIN 命令:
mysql admin -u root -p create db_name
回车输入密码后即创建一个新的数据库 db_name。
三、删除 MySQL 数据库
DROP DATABASE DB_NAME:
drop database db_name;
MYSQLADMIN 命令:
mysqladmin -u root -p drop db_name;
执行以上删除数据库命令后,会出现一个提示框,来确认是否真的删除数据库。
四、选择 MySQL 数据库
USE DB_NAME
use db_name;
五、创建数据表
创建 MySQL 数据表需要以下信息:
- 表名
- 表字段名
- 定义每个表字段
创建 MySQL 数据表的 SQL 通用语法:
CREATE TABLE TB_NAME (COLUMN_NAME COLUMN_TYPE);
create table tb_name (column_name column_type);
如果你不想字段为 NULL,可以设置字段的属性为 NOT NULL,在操作数据库时如果输入该字段的数据为 NULL ,就会报错。如:
create table tb_name (column_nmae column_type not null);
六、删除数据表
DROP TABLE TB_NAME:
drop table tb_name;
七、插入数据
INSERT INTO:
insert into tb_name(column1,column2,..columnN) values(value1,value2,...valueN);
如果数据是字符型,必须使用单引号或者双引号,如:“value”。
八、查询数据
SELECT:
select column_name from tb_name;
查询语句中可以使用一个或者多个表,表之间使用逗号 (,) 分割。
select column_name from tb1,tb2,...tbN;
SELECT 命令可以读取一条或者多条记录。
可以使用星号(*)来代替其他字段,SELECT 语句会返回表的所有字段数据。
WHERE 子句
如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。
可以在 WHERE 子句中指定任何条件,可以使用 AND 或者 OR 指定一个或多个条件。
WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。
select column——name from tb_name where condition1 and condition2;
常用操作符:
等于 | 不等于 | 大于 | 小于 | 大于等于 | 小于等于 |
---|---|---|---|---|---|
= | <>或!= | > | < | >= | <= |
九、UPDATE 更新
如果需要修改或更新 MySQL 中的数据,可以使用 SQL UPDATE 命令来操作。
update tb_name set column=new_vlue;
可选 WHERE 子句指定条件。
十、DELETE 语句
如果需要删除 MySQL 数据表中的记录,可以使用 SQL 的 DELETE 命令来操作。
delete from tb_name [where condition];
可选 WHERE 子句指定条件。
如果没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。
十一、LIKE 子句
WHERE 子句中可以使用等号 = 来设定获取数据的条件。
当需要获取一列中所有含有某些字符的所有记录时,就需要在 WHERE 子句中使用 LIKE 子句。
LIKE 子句中使用百分号 **%**字符来表示任意字符。
从表 tb_name 中获取所有 column_name 中含有 x 的记录:
select * from tb_name where column_name like '%x';
十二、UNION 操作符
UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。
多个 SELECT 语句会删除重复的数据。
select * from tb_name1 union [all | distinc] select * from tb_name2;
Union 中的两个参数:all | distinct
All:返回所有结果集,包含重复数据。
Distinct:删除结果集中重复的数据。(默认)
十三、MySQL 排序
如果需要对读取的数据进行排序,就可以使用 MySQL 的 ORDER BY 子句来设定想按哪个字段哪种方式来进行排序,再返回搜索结果。
按照表 tb_name 中的 column 字段进行排序:
select * from tb_name order by column [asc | desc]
Order by 子句的可选参数:asc (升序) | desc (降序) 默认 asc。
十四、MySQL 分组
GROUP BY:
GROUP BY 语句根据一个或多个列对结果集进行分组。
在分组的列上我们可以使用 COUNT, SUM, AVG, 等函数。
select column_name, operate(column_name) from tb_name group by column_name;
Operate 指 COIUNT、SUM、AVG 等操作。
WITH ROLLUP
WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM, AVG, COUNT…)。
select column_name from tb_name group by column_name with rollup;
可以使用 coalesce 来设置一个可以取代 NUll 的名称,coalesce 语法:
sqselect coalesce(a,b,c);
参数说明:如果a==null,则选择b;如果b==null,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没有意义)。
MySQL 连接的使用*
—-> 使用 MySQL 的 JOIN 在两个或多个表中查询数据。
可以在 SELECT, UPDATE 和 DELETE 语句中使用 Mysql 的 JOIN 来联合多表查询。
JOIN 按照功能大致分为如下三类:
- INNER JOIN(内连接, 或等值连接):获取两个表中字段匹配关系的记录。
- **LEFT JOIN(左连接):**获取左表所有记录,即使右表没有对应匹配的记录。
- RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
INNER JOIN
使用 INNER JOIN 来连接以上两张表来读取 runoob_tbl 表中所有 runoob_author 字段在 tcount_tbl 表对应的 runoob_count 字段值:
SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a INNER JOIN tcount_tbl b ON a.runoob_author = b.runoob_author;
以上 SQL 语句等价于:
SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a, tcount_tbl b WHERE a.runoob_author = b.runoob_author;
LEFT JOIN
LEFT JOIN 与 JOIN 有所不同。LEFT JOIN 会读取左边数据表的全部数据,即便右边表无对应数据。
以 runoob_tbl 为左表,tcount_tbl 为右表:
mysql> SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a LEFT JOIN tcount_tbl b ON a.runoob_author = b.runoob_author;
以上实例中使用了 LEFT JOIN,该语句会读取左边的数据表 runoob_tbl 的所有选取的字段数据,即便在右侧表 tcount_tbl 中没有对应的 runoob_author 字段值。
RIGHT JOIN
RIGHT JOIN 会读取右边数据表的全部数据,即便左边边表无对应数据。
以 runoob_tbl 为左表,tcount_tbl 为右表:
SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a RIGHT JOIN tcount_tbl b ON a.runoob_author = b.runoob_author;
以上实例中使用了 RIGHT JOIN,该语句会读取右边的数据表 tcount_tbl 的所有选取的字段数据,即便在左侧表 runoob_tbl 中没有对应的 runoob_author 字段值。
MySQL NULL 值处理
MySQL 使用 SELECT 命令及 WHERE 子句来读取数据表中的数据, 但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。
为了处理这种情况,MySQL 提供了三大运算符:
- IS NULL: 当列的值是 NULL, 返回 true。
- IS NOT NULL: 当列的值不为 NULL, 返回 true。
- <=>: 比较操作符,当比较的的两个值相等或者都为 NULL 时返回 true。(区别于 = )
几点注意:
1、不能使用 = NULL 或 != NULL 在列中查找 NULL 值。
2、在 MySQL 中,NULL 值与任何其它值的比较永远返回 NULL。
3、MySQL 中处理 NULL 使用 IS NULL 和 IS NOT NULL 运算符。
假设表 tb_name 中有两列字段,其中一列字段含有 NULL 值,执行以下命令:
select * from tb_name where column_name=NULL;
select * from tb_name where column_name!=NULL;
两条语句均没有返回值,说明 = 和 != 不起作用。
查找表中某字段是否为 NULL 必须使用 IS NULL 和 IS NOT NULL 语句。
select * from tb_name where column_name IS NULL;
select * from tb_name where column_name IS NOT NULL;
MySQL 中的正则表达式*
下表中的正则模式可应用于 REGEXP 操作符中。
模式 | 描述 |
---|---|
^ | 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置。 |
$ | 匹配输入字符串的结束位置。如果设置了 RegExp 对象的 Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置。 |
. | 匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用像 ‘[.\n]’ 的模式。 |
[…] | 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’。 |
[^…] | 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’。 |
p 1|p 2|p 3 | 匹配 p 1 或 p 2 或 p 3。例如,‘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 正则表达式的实例:
查找 name 字段中以’st’为开头的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP '^st';
查找 name 字段中以’ok’为结尾的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP 'ok$';
查找 name 字段中包含’mar’字符串的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP 'mar';
查找 name 字段中以元音字符开头或以’ok’字符串结尾的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';
MySQL 事务
MySQL 事务主要用于处理操作量大,复杂度高的数据。
- 在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
- 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
- 事务用来管理 **insert **, update, delete 语句。
- 一个完整的业务需要批量的 DML (insert、update、delete) 语句共同联合完成。
一般来说,事务是必须满足 4 个条件:原子性、一致性、隔离性、持久性。
- **原子性:**一个事务中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚到事务开始前的状态,就像这个事务从来没有执行过一样。
- **一致性:**在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。
- **隔离性:**数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交、读提交、可重复读和串行化。
- **持久性:**事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。
关于事务的一些术语
- 开启事务:Start Transaction
- 事务结束:End Transaction
- 提交事务*:Commit Transaction
- 回滚事务*:Rollback Transaction
MYSQL 事务处理主要有两种方法:
1、用 BEGIN, ROLLBACK, COMMIT 来实现
- BEGIN 开始一个事务
- ROLLBACK 事务回滚
- COMMIT 事务确认
2、直接用 SET 来改变 MySQL 的自动提交模式:
- SET AUTOCOMMIT=0 禁止自动提交
- SET AUTOCOMMIT=1 开启自动提交
MySQL ALTER 命令
当需要修改数据表名或者修改数据表字段时,就需要使用到 ALTER 命令。
一、删除,添加或修改表字段
使用 ALTER 命令及 DROP 子句来删除表中的 column_name 字段:
alter table tb_name drop column_name;
注:如果数据表中只剩余一个字段则无法使用 DROP 来删除字段。
MySQL 中使用 ADD 子句来向数据表中添加列。
使用 ALTER 命令及 ADD 子句向表 tb_name 中添加 column_name 字段。
alter table tb_name add column_name column_type;
执行以上命令后,column_name 字段会自动添加到数据表字段的末尾。
注:记得加上字段类型 column_type。
使用 FIRST、AFTER 关键字来确定插入字段的位置。
alter table tb_name add column_name column_type first; //把新增的字段设为第一列
alter table tb_name add column_name column_type after x; //把新增的字段放在字段x后
注:使用 SHOW COLUMNS 可以查看表结构的变化。
二、修改字段类型及名称
如果要修改字段类型及名称, 可以在 ALTER 命令中使用 MODIFY 或 CHANGE 子句。
1、使用 MODIFY 子句修改字段 column_name 的类型:从 char (0) 改为 char (10):
alter table tb_name modify column_name char(10);
2、使用 CHANGE 子句修改字段 column_name 的名字及类型:
alter tbale tb_name change column_name1 column_name2 column_newtype;
三、ALTER TABLE 对 Null 值和默认值的影响
当修改字段时,可以指定该字段是否包含值或者是否设置默认值。
指定字段 column_name 为 NOT NULL 且默认值为 100:
alter table tb_name modify column_name column_type NOT NULL defaule 100;
修改字段 column_name 的默认值为 1000:
alter table tb_name alter column_name set default 1000;
使用 ALTER 命令及 DROP 子句来删除字段 column_name 的默认值:
alter table tb_name alter column_name drop default;
使用 ALTER 命令及 TYPE 子句来修改数据表类型:
alter table tb_name engine=tb_type;
注:查看数据表类型可以使用 SHOW TABLE STATUS 语句。
四、修改表名
如果要修改字段类型及名称, 可以在 ALTER 命令中使用 RENAME 子句。
将表 tb_name 0 的名字改为 tb_name 1:
alter table tb_name1 rename to tb_name1;
MySQL 索引
索引分单列索引和组合索引。
单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。
组合索引,即一个索引包含多个列。
索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。
索引能够提高查询速度,但同时会降低更新速度。
普通索引
一、创建索引
语法格式:
create index index_name on tb_name(column_name);
二、添加索引
语法格式:
alter table tb_name add index index_name(column_name);
三、创建表时指定索引
语法格式:
create table tb_name(column_name column_type,index [index_name] cloumn_name);
四、删除索引
语法格式:
drop index [indext_name] on tb_name;
唯一索引
唯一索引的值必须唯一,但允许有空值。
一、创建索引
语法格式:
create unique index index_name on tb_name(column_name);
二、修改表结构
语法格式:
alter table tb_name add unique [index_name] (column_name);
三、创建表的时候直接指定
语法格式:
create table tb_name(column_name,column_type,unique [index_name] (username(length)));
四、显示索引信息
语法格式:
show index from tb_name\G;
MySQL 临时表
临时表用于保存临时数据。
临时表只在当前连接可见,当关闭连接时,Mysql 会自动删除表并释放所有空间。
如果使用 PHP 脚本来创建 MySQL 临时表,那每当 PHP 脚本执行完成后,该临时表也会自动销毁。
一、创建临时表
create temporary table tb_name(column_name,column_type,[not null]);
二、向临时表中添加元素
insert into tb_name(column_name) values(value);
三、查找临时表中的元素
select * from tb_name;
四、删除临时表
默认情况下,当断开与数据库的连接后,临时表就会自动被销毁。
当然也可以在连接状态下手动删除:
drop table tb_name;
MySQL 复制表
用于复制完整的 MySQL 数据表,包括表的结构,索引,默认值等。
1、获取数据表的完整结构
show create table tb_name\G;
2、修改 SQL 语句的数据表名,并执行 SQL 语句。
create table cp_tb_name(column_name,column_type,....);
3、执行完第二步后,在数据库中创建新的克隆表 cp_yb_name ,要拷贝数据时,使用 insert into… Select 语句实现。
insert into cp_tb_name(column_name) select column_name from tb_name;
执行以上步骤后,会完整的复制表的内容,包括表结构及表数据。
MySQL 函数
MySQL 字符串函数
函数 | 描述 | 实例 |
---|---|---|
ASCII (s) | 返回字符串 s 的第一个字符的 ASCII 码。 | 返回 CustomerName 字段第一个字母的 ASCII 码:SELECT ASCII (CustomerName) AS NumCodeOfFirstChar FROM Customers; |
CHAR_LENGTH (s) | 返回字符串 s 的字符数 | 返回字符串 RUNOOB 的字符数SELECT CHAR_LENGTH ("RUNOOB") AS LengthOfString; |
CHARACTER_LENGTH (s) | 返回字符串 s 的字符数,等同于 CHAR_LENGTH (s) | 返回字符串 RUNOOB 的字符数SELECT CHARACTER_LENGTH ("RUNOOB") AS LengthOfString; |
CONCAT (s 1, s 2… Sn) | 字符串 s 1, s 2 等多个字符串合并为一个字符串 | 合并多个字符串SELECT CONCAT ("SQL ", "Runoob ", "Gooogle ", "Facebook") AS ConcatenatedString; |
CONCAT_WS (x, s 1, s 2… Sn) | 同 CONCAT (s 1, s 2,…) 函数,但是每个字符串之间要加上 x,x 可以是分隔符 | 合并多个字符串,并添加分隔符:SELECT CONCAT_WS ("-", "SQL", "Tutorial", "is", "fun!") AS ConcatenatedString; |
FIELD (s, s 1, s 2…) | 返回第一个字符串 s 在字符串列表 (s 1, s 2…) 中的位置 | 返回字符串 c 在列表值中的位置:SELECT FIELD ("c", "a", "b", "c", "d", "e"); |
FIND_IN_SET (s 1, s 2) | 返回在字符串 s 2 中与 s 1 匹配的字符串的位置 | 返回字符串 c 在指定字符串中的位置:SELECT FIND_IN_SET ("c", "a, b, c, d, e"); |
FORMAT (x, n) | 函数可以将数字 x 进行格式化 “#,###.##”, 将 x 保留到小数点后 n 位,最后一位四舍五入。 | 格式化数字 “#,###.##” 形式:SELECT FORMAT (250500.5634, 2); -- 输出 250,500.56 |
INSERT (s 1, x, len, s 2) | 字符串 s 2 替换 s 1 的 x 位置开始长度为 len 的字符串 | 从字符串第一个位置开始的 6 个字符替换为 runoob:SELECT INSERT ("google. Com", 1, 6, "runoob"); -- 输出:runoob. Com |
LOCATE (s 1, s) | 从字符串 s 中获取 s 1 的开始位置 | 获取 b 在字符串 abc 中的位置:SELECT LOCATE ('st','myteststring'); -- 5 返回字符串 abc 中 b 的位置:SELECT LOCATE ('b', 'abc') -- 2 |
LCASE (s) | 将字符串 s 的所有字母变成小写字母 | 字符串 RUNOOB 转换为小写:SELECT LCASE ('RUNOOB') -- runoob |
LEFT (s, n) | 返回字符串 s 的前 n 个字符 | 返回字符串 runoob 中的前两个字符:SELECT LEFT ('runoob', 2) -- ru |
LOWER (s) | 将字符串 s 的所有字母变成小写字母 | 字符串 RUNOOB 转换为小写:SELECT LOWER ('RUNOOB') -- runoob |
LPAD (s 1, len, s 2) | 在字符串 s 1 的开始处填充字符串 s 2,使字符串长度达到 len | 将字符串 xx 填充到 abc 字符串的开始处:SELECT LPAD ('abc', 5,'xx') -- xxabc |
LTRIM (s) | 去掉字符串 s 开始处的空格 | 去掉字符串 RUNOOB 开始处的空格:SELECT LTRIM (" RUNOOB") AS LeftTrimmedString;-- RUNOOB |
MID (s, n, len) | 从字符串 s 的 n 位置截取长度为 len 的子字符串,同 SUBSTRING (s, n, len) | 从字符串 RUNOOB 中的第 2 个位置截取 3 个字符:SELECT MID ("RUNOOB", 2, 3) AS ExtractString; -- UNO |
POSITION (s 1 IN s) | 从字符串 s 中获取 s 1 的开始位置 | 返回字符串 abc 中 b 的位置:SELECT POSITION ('b' in 'abc') -- 2 |
REPEAT (s, n) | 将字符串 s 重复 n 次 | 将字符串 runoob 重复三次:SELECT REPEAT ('runoob', 3) -- runoobrunoobrunoob |
REPLACE (s, s 1, s 2) | 将字符串 s 2 替代字符串 s 中的字符串 s 1 | 将字符串 abc 中的字符 a 替换为字符 x:SELECT REPLACE ('abc','a','x') --xbc |
REVERSE (s) | 将字符串 s 的顺序反过来 | 将字符串 abc 的顺序反过来:SELECT REVERSE ('abc') -- cba |
RIGHT (s, n) | 返回字符串 s 的后 n 个字符 | 返回字符串 runoob 的后两个字符:SELECT RIGHT ('runoob', 2) -- ob |
RPAD (s 1, len, s 2) | 在字符串 s 1 的结尾处添加字符串 s 2,使字符串的长度达到 len | 将字符串 xx 填充到 abc 字符串的结尾处:SELECT RPAD ('abc', 5,'xx') -- abcxx |
RTRIM (s) | 去掉字符串 s 结尾处的空格 | 去掉字符串 RUNOOB 的末尾空格:SELECT RTRIM ("RUNOOB ") AS RightTrimmedString; -- RUNOOB |
SPACE (n) | 返回 n 个空格 | 返回 10 个空格:SELECT SPACE (10); |
STRCMP (s 1, s 2) | 比较字符串 s 1 和 s 2,如果 s 1 与 s 2 相等返回 0 ,如果 s 1>s 2 返回 1,如果 s 1<s 2 返回 -1 | 比较字符串:SELECT STRCMP ("runoob", "runoob"); -- 0 |
SUBSTR (s, start, length) | 从字符串 s 的 start 位置截取长度为 length 的子字符串 | 从字符串 RUNOOB 中的第 2 个位置截取 3 个字符:SELECT SUBSTR ("RUNOOB", 2, 3) AS ExtractString; -- UNO |
SUBSTRING (s, start, length) | 从字符串 s 的 start 位置截取长度为 length 的子字符串,等同于 SUBSTR (s, start, length) | 从字符串 RUNOOB 中的第 2 个位置截取 3 个字符:SELECT SUBSTRING ("RUNOOB", 2, 3) AS ExtractString; -- UNO |
SUBSTRING_INDEX (s, delimiter, number) | 返回从字符串 s 的第 number 个出现的分隔符 delimiter 之后的子串。如果 number 是正数,返回第 number 个字符左边的字符串。如果 number 是负数,返回第 (number 的绝对值 (从右边数)) 个字符右边的字符串。 | SELECT SUBSTRING_INDEX ('a*b','*', 1) -- a SELECT SUBSTRING_INDEX ('a*b','*',-1) -- b SELECT SUBSTRING_INDEX (SUBSTRING_INDEX ('a*b*c*d*e','*', 3),'*',-1) -- c |
TRIM (s) | 去掉字符串 s 开始和结尾处的空格 | 去掉字符串 RUNOOB 的首尾空格:SELECT TRIM (' RUNOOB ') AS TrimmedString; |
UCASE (s) | 将字符串转换为大写 | 将字符串 runoob 转换为大写:SELECT UCASE ("runoob"); -- RUNOOB |
UPPER (s) | 将字符串转换为大写 | 将字符串 runoob 转换为大写:SELECT UPPER ("runoob"); -- RUNOOB |
MySQL 数字函数
函数名 | 描述 | 实例 |
---|---|---|
ABS (x) | 返回 x 的绝对值 | 返回 -1 的绝对值:SELECT ABS (-1) -- 返回 1 |
ACOS (x) | 求 x 的反余弦值(单位为弧度),x 为一个数值 | SELECT ACOS (0.25); |
ASIN (x) | 求反正弦值(单位为弧度),x 为一个数值 | SELECT ASIN (0.25); |
ATAN (x) | 求反正切值(单位为弧度),x 为一个数值 | SELECT ATAN (2.5); |
ATAN 2 (n, m) | 求反正切值(单位为弧度) | SELECT ATAN 2 (-0.8, 2); |
AVG (expression) | 返回一个表达式的平均值,expression 是一个字段 | 返回 Products 表中 Price 字段的平均值:SELECT AVG (Price) AS AveragePrice FROM Products; |
CEIL (x) | 返回大于或等于 x 的最小整数 | SELECT CEIL (1.5) -- 返回 2 |
CEILING (x) | 返回大于或等于 x 的最小整数 | SELECT CEILING (1.5); -- 返回 2 |
COS (x) | 求余弦值 (参数是弧度) | SELECT COS (2); |
COT (x) | 求余切值 (参数是弧度) | SELECT COT (6); |
COUNT (expression) | 返回查询的记录总数,expression 参数是一个字段或者 * 号 | 返回 Products 表中 products 字段总共有多少条记录:SELECT COUNT (ProductID) AS NumberOfProducts FROM Products; |
DEGREES (x) | 将弧度转换为角度 | SELECT DEGREES (3.1415926535898) -- 180 |
n DIV m | 整除,n 为被除数,m 为除数 | 计算 10 除于 5:SELECT 10 DIV 5; -- 2 |
EXP (x) | 返回 e 的 x 次方 | 计算 e 的三次方:SELECT EXP (3) -- 20.085536923188 |
FLOOR (x) | 返回小于或等于 x 的最大整数 | 小于或等于 1.5 的整数:SELECT FLOOR (1.5) -- 返回 1 |
GREATEST (expr 1, expr 2, expr 3, …) | 返回列表中的最大值 | 返回以下数字列表中的最大值:SELECT GREATEST (3, 12, 34, 8, 25); -- 34 返回以下字符串列表中的最大值:SELECT GREATEST ("Google", "Runoob", "Apple"); -- Runoob |
LEAST (expr 1, expr 2, expr 3, …) | 返回列表中的最小值 | 返回以下数字列表中的最小值:SELECT LEAST (3, 12, 34, 8, 25); -- 3 返回以下字符串列表中的最小值:SELECT LEAST ("Google", "Runoob", "Apple"); -- Apple |
LN | 返回数字的自然对数,以 e 为底。 | 返回 2 的自然对数:SELECT LN (2); -- 0.6931471805599453 |
LOG (x) 或 LOG (base, x) | 返回自然对数 (以 e 为底的对数),如果带有 base 参数,则 base 为指定带底数。 | SELECT LOG (20.085536923188) -- 3 SELECT LOG (2, 4); -- 2 |
LOG 10 (x) | 返回以 10 为底的对数 | SELECT LOG 10 (100) -- 2 |
LOG 2 (x) | 返回以 2 为底的对数 | 返回以 2 为底 6 的对数:SELECT LOG 2 (6); -- 2.584962500721156 |
MAX (expression) | 返回字段 expression 中的最大值 | 返回数据表 Products 中字段 Price 的最大值:SELECT MAX (Price) AS LargestPrice FROM Products; |
MIN (expression) | 返回字段 expression 中的最小值 | 返回数据表 Products 中字段 Price 的最小值:SELECT MIN (Price) AS MinPrice FROM Products; |
MOD (x, y) | 返回 x 除以 y 以后的余数 | 5 除于 2 的余数:SELECT MOD (5,2) -- 1 |
PI () | 返回圆周率 (3.141593) | SELECT PI () --3.141593 |
POW (x, y) | 返回 x 的 y 次方 | 2 的 3 次方:SELECT POW (2,3) -- 8 |
POWER (x, y) | 返回 x 的 y 次方 | 2 的 3 次方:SELECT POWER (2,3) -- 8 |
RADIANS (x) | 将角度转换为弧度 | 180 度转换为弧度:SELECT RADIANS (180) -- 3.1415926535898 |
RAND () | 返回 0 到 1 的随机数 | SELECT RAND () --0.93099315644334 |
ROUND (x) | 返回离 x 最近的整数 | SELECT ROUND (1.23456) --1 |
SIGN (x) | 返回 x 的符号,x 是负数、0、正数分别返回 -1、0 和 1 | SELECT SIGN (-10) -- (-1) |
SIN (x) | 求正弦值 (参数是弧度) | SELECT SIN (RADIANS (30)) -- 0.5 |
SQRT (x) | 返回 x 的平方根 | 25 的平方根:SELECT SQRT (25) -- 5 |
SUM (expression) | 返回指定字段的总和 | 计算 OrderDetails 表中字段 Quantity 的总和:SELECT SUM (Quantity) AS TotalItemsOrdered FROM OrderDetails; |
TAN (x) | 求正切值 (参数是弧度) | SELECT TAN (1.75); -- -5.52037992250933 |
TRUNCATE (x, y) | 返回数值 x 保留到小数点后 y 位的值(与 ROUND 最大的区别是不会进行四舍五入) | SELECT TRUNCATE (1.23456,3) -- 1.234 |
MySQL 日期函数
函数名 | 描述 |
---|---|
ADDDATE (d, n) | 计算起始日期 d 加上 n 天的日期 |
ADDTIME (t, n) | n 是一个时间表达式,时间 t 加上时间表达式 n |
CURDATE () | 返回当前日期 |
CURRENT_DATE () | 返回当前日期 |
CURRENT_TIME | 返回当前时间 |
CURRENT_TIMESTAMP () | 返回当前日期和时间 |
CURTIME () | 返回当前时间 |
DATE () | 从日期或日期时间表达式中提取日期值 |
DATEDIFF (d 1, d 2) | 计算日期 d 1->d 2 之间相隔的天数 |
DATE_ADD (d,INTERVAL expr type) | 计算起始日期 d 加上一个时间段后的日期, |
DATE_FORMAT (d, f) | 按表达式 f 的要求显示日期 d |
DATE_SUB (date, INTERVAL expr type) | 函数从日期减去指定的时间间隔。 |
DAY (d) | 返回日期值 d 的日期部分 |
DAYNAME (d) | 返回日期 d 是星期几,如 Monday, Tuesday |
DAYOFMONTH (d) | 计算日期 d 是本月的第几天 |
DAYOFWEEK (d) | 日期 d 今天是星期几,1 星期日,2 星期一,以此类推 |
DAYOFYEAR (d) | 计算日期 d 是本年的第几天 |
EXTRACT (type FROM d) | 从日期 d 中获取指定的值,type 指定返回的值。 |
FROM_DAYS (n) | 计算从 0000 年 1 月 1 日开始 n 天后的日期 |
HOUR (t) | 返回 t 中的小时值 |
LAST_DAY (d) | 返回给给定日期的那一月份的最后一天 |
LOCALTIME () | 返回当前日期和时间 |
LOCALTIMESTAMP () | 返回当前日期和时间 |
MAKEDATE (year, day-of-year) | 基于给定参数年份 year 和所在年中的天数序号 day-of-year 返回一个日期 |
MAKETIME (hour, minute, second) | 组合时间,参数分别为小时、分钟、秒 |
MICROSECOND (date) | 返回日期参数所对应的微秒数 |
MINUTE (t) | 返回 t 中的分钟值 |
MONTHNAME (d) | 返回日期当中的月份名称,如 November |
MONTH (d) | 返回日期 d 中的月份值,1 到 12 |
NOW () | 返回当前日期和时间 |
PERIOD_ADD (period, number) | 为年-月组合日期添加一个时段 |
PERIOD_DIFF (period 1, period 2) | 返回两个时段之间的月份差值 |
QUARTER (d) | 返回日期 d 是第几季节,返回 1 到 4 |
SECOND (t) | 返回 t 中的秒钟值 |
SEC_TO_TIME (s) | 将以秒为单位的时间 s 转换为时分秒的格式 |
STR_TO_DATE (string, format_mask) | 将字符串转变为日期 |
SUBDATE (d, n) | 日期 d 减去 n 天后的日期 |
SUBTIME (t, n) | 时间 t 减去 n 秒的时间 |
SYSDATE () | 返回当前日期和时间 |
TIME (expression) | 提取传入表达式的时间部分 |
TIME_FORMAT (t, f) | 按表达式 f 的要求显示时间 t |
TIME_TO_SEC (t) | 将时间 t 转换为秒 |
TIMEDIFF (time 1, time 2) | 计算时间差值 |
TIMESTAMP (expression, interval) | 单个参数时,函数返回日期或日期时间表达式;有 2 个参数时,将参数加和 |
TIMESTAMPDIFF (unit, datetime_expr 1, datetime_expr 2) | 计算时间差,返回 datetime_expr 2 − datetime_expr 1 的时间差 |
TO_DAYS (d) | 计算日期 d 距离 0000 年 1 月 1 日的天数 |
WEEK (d) | 计算日期 d 是本年的第几个星期,范围是 0 到 53 |
WEEKDAY (d) | 日期 d 是星期几,0 表示星期一,1 表示星期二 |
WEEKOFYEAR (d) | 计算日期 d 是本年的第几个星期,范围是 0 到 53 |
YEAR (d) | 返回年份 |
YEARWEEK (date, mode) | 返回年份及第几周(0 到 53),mode 中 0 表示周天,1 表示周一,以此类推 |
MySQL 高级函数
函数名 | 描述 | 实例 |
---|---|---|
BIN (x) | 返回 x 的二进制编码 | 15 的 2 进制编码:SELECT BIN (15); -- 1111 |
BINARY (s) | 将字符串 s 转换为二进制字符串 | SELECT BINARY "RUNOOB"; -> RUNOOB |
CASE expression WHEN condition 1 THEN result 1 WHEN condition 2 THEN result 2 ... WHEN conditionN THEN resultN ELSE result END |
CASE 表示函数开始,END 表示函数结束。如果 condition 1 成立,则返回 result 1, 如果 condition 2 成立,则返回 result 2,当全部不成立则返回 result,而当有一个成立之后,后面的就不执行了。 | SELECT CASE WHEN 1 > 0 THEN '1 > 0' WHEN 2 > 0 THEN '2 > 0' ELSE '3 > 0' END ->1 > 0 |
CAST (x AS type) | 转换数据类型 | 字符串日期转换为日期:SELECT CAST ("2017-08-29" AS DATE); -> 2017-08-29 |
COALESCE (expr 1, expr 2, …., expr_n) | 返回参数中的第一个非空表达式(从左向右) | SELECT COALESCE (NULL, NULL, NULL, 'runoob. Com', NULL, 'google. Com'); -> runoob. Com |
CONNECTION_ID () | 返回唯一的连接 ID | SELECT CONNECTION_ID (); -> 4292835 |
CONV (x, f 1, f 2) | 返回 f 1 进制数变成 f 2 进制数 | SELECT CONV (15, 10, 2); -> 1111 |
CONVERT (s USING cs) | 函数将字符串 s 的字符集变成 cs | SELECT CHARSET ('ABC') ->utf-8 SELECT CHARSET (CONVERT ('ABC' USING gbk)) ->gbk |
CURRENT_USER () | 返回当前用户 | SELECT CURRENT_USER (); -> guest@% |
DATABASE () | 返回当前数据库名 | SELECT DATABASE (); -> runoob |
IF (expr, v 1, v 2) | 如果表达式 expr 成立,返回结果 v 1;否则,返回结果 v 2。 | SELECT IF (1 > 0,'正确','错误') ->正确 |
IFNULL(v1,v2) | 如果 v 1 的值不为 NULL,则返回 v 1,否则返回 v 2。 | SELECT IFNULL (null,'Hello Word') ->Hello Word |
ISNULL (expression) | 判断表达式是否为 NULL | SELECT ISNULL (NULL); ->1 |
LAST_INSERT_ID () | 返回最近生成的 AUTO_INCREMENT 值 | SELECT LAST_INSERT_ID (); ->6 |
NULLIF (expr 1, expr 2) | 比较两个字符串,如果字符串 expr 1 与 expr 2 相等返回 NULL,否则返回 expr 1 | SELECT NULLIF (25, 25); -> |
SESSION_USER () | 返回当前用户 | SELECT SESSION_USER (); -> guest@% |
SYSTEM_USER () | 返回当前用户 | SELECT SYSTEM_USER (); -> guest@% |
USER () | 返回当前用户 | SELECT USER (); -> guest@% |
VERSION () | 返回数据库的版本号 | SELECT VERSION () -> 5.6.34 |
MySQL 运算符
算术运算符
MySQL 支持的算术运算符包括:
运算符 | 作用 |
---|---|
+ | 加法 |
- | 减法 |
* | 乘法 |
/ 或 DIV | 除法 |
% 或 MOD | 取余 |
在除法运算和模运算中,如果除数为 0,将是非法除数,返回结果为 NULL。
比较运算符
SELECT 语句中的条件语句经常要使用比较运算符。通过这些比较运算符,可以判断表中的哪些记录是符合条件的。比较结果为真,则返回 1,为假则返回 0,比较结果不确定则返回 NULL。
符号 | 描述 | 备注 |
---|---|---|
= | 等于 | |
<>, != | 不等于 | |
> | 大于 | |
< | 小于 | |
<= | 小于等于 | |
>= | 大于等于 | |
BETWEEN | 在两值之间 | >=min&&<=max |
NOT BETWEEN | 不在两值之间 | |
IN | 在集合中 | |
NOT IN | 不在集合中 | |
<=> | 严格比较两个 NULL 值是否相等 | 两个操作码均为 NULL 时,其所得值为 1;而当一个操作码为 NULL 时,其所得值为 0 |
LIKE | 模糊匹配 | |
REGEXP 或 RLIKE | 正则式匹配 | |
IS NULL | 为空 | |
IS NOT NULL | 不为空 |
逻辑运算符
逻辑运算符用来判断表达式的真假。如果表达式是真,结果返回 1。如果表达式是假,结果返回 0。
运算符号 | 作用 |
---|---|
NOT 或 ! | 逻辑非 |
AND | 逻辑与 |
OR | 逻辑或 |
XOR | 逻辑异或 |
位运算符
位运算符是在二进制数上进行计算的运算符。位运算会先将操作数变成二进制数,进行位运算。然后再将计算结果从二进制数变回十进制数。
运算符号 | 作用 |
---|---|
& | 按位与 |
| | 按位或 |
^ | 按位异或 |
! | 取反 |
« | 左移 |
» | 右移 |