全国思政网站的建设情况,seo优化网站优化排名,使用密码访问wordpress文章,网页版传奇源码文章目录 基础篇通用语法及分类DDL#xff08;数据定义语言#xff09;数据库操作注意事项 表操作 DML#xff08;数据操作语言#xff09;添加数据注意事项 更新和删除数据 DQL#xff08;数据查询语言#xff09;基础查询条件查询聚合查询#xff08;聚合函数#xf… 文章目录 基础篇通用语法及分类DDL数据定义语言数据库操作注意事项 表操作 DML数据操作语言添加数据注意事项 更新和删除数据 DQL数据查询语言基础查询条件查询聚合查询聚合函数分组查询注意事项 排序查询注意事项 分页查询注意事项 DQL执行顺序 DCL管理用户注意事项 权限控制注意事项 函数字符串函数数值函数日期函数流程函数 约束常用约束外键约束删除/更新行为 多表查询多表关系一对多多对多一对一 查询内连接查询外连接查询自连接查询联合查询 union, union all注意事项 子查询标量子查询列子查询行子查询表子查询 事务四大特性ACID并发事务 进阶篇存储引擎InnoDBMyISAMMemory存储引擎特点存储引擎的选择 性能分析查看执行频次慢查询日志profileexplain 索引索引结构B-TreeBTreeHash面试题 索引分类思考题 语法使用规则最左前缀法则索引失效情况SQL 提示覆盖索引回表查询前缀索引单列索引联合索引注意事项 设计原则 SQL 优化插入数据主键优化order by优化group by优化limit优化count优化update优化避免行锁升级为表锁 数据类型整型浮点型日期和时间字符串二进制类型 权限一览表图形化界面工具安装小技巧 本套笔记配套的视频教程 转载自此网站
基础篇
通用语法及分类
DDL: 数据定义语言用来定义数据库对象数据库、表、字段DML: 数据操作语言用来对数据库表中的数据进行增删改DQL: 数据查询语言用来查询数据库中表的记录DCL: 数据控制语言用来创建数据库用户、控制数据库的控制权限
DDL数据定义语言
数据定义语言
数据库操作
查询所有数据库 SHOW DATABASES; 查询当前数据库 SELECT DATABASE(); 创建数据库 CREATE DATABASE [ IF NOT EXISTS ] 数据库名 [ DEFAULT CHARSET 字符集] [COLLATE 排序规则 ]; 删除数据库 DROP DATABASE [ IF EXISTS ] 数据库名; 使用数据库 USE 数据库名;
注意事项
UTF8字符集长度为3字节有些符号占4字节所以推荐用utf8mb4字符集
表操作
查询当前数据库所有表 SHOW TABLES; 查询表结构 DESC 表名; 查询指定表的建表语句 SHOW CREATE TABLE 表名;
创建表
CREATE TABLE 表名(字段1 字段1类型 [COMMENT 字段1注释],字段2 字段2类型 [COMMENT 字段2注释],字段3 字段3类型 [COMMENT 字段3注释],...字段n 字段n类型 [COMMENT 字段n注释]
)[ COMMENT 表注释 ];最后一个字段后面没有逗号
添加字段 ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束]; 例ALTER TABLE emp ADD nickname varchar(20) COMMENT 昵称;
修改数据类型 ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度); 修改字段名和字段类型 ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度) [COMMENT 注释] [约束]; 例将emp表的nickname字段修改为username类型为varchar(30) ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT 昵称;
删除字段 ALTER TABLE 表名 DROP 字段名;
修改表名 ALTER TABLE 表名 RENAME TO 新表名
删除表 DROP TABLE [IF EXISTS] 表名; 删除表并重新创建该表 TRUNCATE TABLE 表名;
DML数据操作语言
添加数据
指定字段 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...); 全部字段 INSERT INTO 表名 VALUES (值1, 值2, ...);
批量添加数据 INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...); INSERT INTO 表名 VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...);
注意事项
字符串和日期类型数据应该包含在引号中插入的数据大小应该在字段的规定范围内
更新和删除数据
修改数据 UPDATE 表名 SET 字段名1 值1, 字段名2 值2, ... [ WHERE 条件 ]; 例 UPDATE emp SET name Jack WHERE id 1;
删除数据 DELETE FROM 表名 [ WHERE 条件 ];
DQL数据查询语言
语法
SELECT字段列表
FROM表名字段
WHERE条件列表
GROUP BY分组字段列表
HAVING分组后的条件列表
ORDER BY排序字段列表
LIMIT分页参数基础查询
查询多个字段 SELECT 字段1, 字段2, 字段3, ... FROM 表名; SELECT * FROM 表名;
设置别名 SELECT 字段1 [ AS 别名1 ], 字段2 [ AS 别名2 ], 字段3 [ AS 别名3 ], ... FROM 表名; SELECT 字段1 [ 别名1 ], 字段2 [ 别名2 ], 字段3 [ 别名3 ], ... FROM 表名;
去除重复记录 SELECT DISTINCT 字段列表 FROM 表名;
转义 SELECT * FROM 表名 WHERE name LIKE /_张三 ESCAPE / / 之后的_不作为通配符
条件查询
语法 SELECT 字段列表 FROM 表名 WHERE 条件列表;
条件
比较运算符功能大于大于等于小于小于等于等于 或 !不等于BETWEEN … AND …在某个范围内含最小、最大值IN(…)在in之后的列表中的值多选一LIKE 占位符模糊匹配_匹配单个字符%匹配任意个字符IS NULL是NULL
逻辑运算符功能AND 或 并且多个条件同时成立OR 或 ||或者多个条件任意一个成立NOT 或 !非不是
例子
-- 年龄等于30
select * from employee where age 30;
-- 年龄小于30
select * from employee where age 30;
-- 小于等于
select * from employee where age 30;
-- 没有身份证
select * from employee where idcard is null or idcard ;
-- 有身份证
select * from employee where idcard;
select * from employee where idcard is not null;
-- 不等于
select * from employee where age ! 30;
-- 年龄在20到30之间
select * from employee where age between 20 and 30;
select * from employee where age 20 and age 30;
-- 下面语句不报错但查不到任何信息
select * from employee where age between 30 and 20;
-- 性别为女且年龄小于30
select * from employee where age 30 and gender 女;
-- 年龄等于25或30或35
select * from employee where age 25 or age 30 or age 35;
select * from employee where age in (25, 30, 35);
-- 姓名为两个字
select * from employee where name like __;
-- 身份证最后为X
select * from employee where idcard like %X;聚合查询聚合函数
常见聚合函数
函数功能count统计数量max最大值min最小值avg平均值sum求和
语法 SELECT 聚合函数(字段列表) FROM 表名; 例 SELECT count(id) from employee where workaddress 广东省;
分组查询
语法 SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组后的过滤条件 ];
where 和 having 的区别
执行时机不同where是分组之前进行过滤不满足where条件不参与分组having是分组后对结果进行过滤。判断条件不同where不能对聚合函数进行判断而having可以。
例子
-- 根据性别分组统计男性和女性数量只显示分组数量不显示哪个是男哪个是女
select count(*) from employee group by gender;
-- 根据性别分组统计男性和女性数量
select gender, count(*) from employee group by gender;
-- 根据性别分组统计男性和女性的平均年龄
select gender, avg(age) from employee group by gender;
-- 年龄小于45并根据工作地址分组
select workaddress, count(*) from employee where age 45 group by workaddress;
-- 年龄小于45并根据工作地址分组获取员工数量大于等于3的工作地址
select workaddress, count(*) address_count from employee where age 45 group by workaddress having address_count 3;注意事项
执行顺序where 聚合函数 having分组之后查询的字段一般为聚合函数和分组字段查询其他字段无任何意义
排序查询
语法 SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1, 字段2 排序方式2;
排序方式
ASC: 升序默认DESC: 降序
例子
-- 根据年龄升序排序
SELECT * FROM employee ORDER BY age ASC;
SELECT * FROM employee ORDER BY age;
-- 两字段排序根据年龄升序排序入职时间降序排序
SELECT * FROM employee ORDER BY age ASC, entrydate DESC;注意事项
如果是多字段排序当第一个字段值相同时才会根据第二个字段进行排序
分页查询
语法 SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数;
例子
-- 查询第一页数据展示10条
SELECT * FROM employee LIMIT 0, 10;
-- 查询第二页
SELECT * FROM employee LIMIT 10, 10;注意事项
起始索引从0开始起始索引 查询页码 - 1 * 每页显示记录数分页查询是数据库的方言不同数据库有不同实现MySQL是LIMIT如果查询的是第一页数据起始索引可以省略直接简写 LIMIT 10
DQL执行顺序
FROM - WHERE - GROUP BY - SELECT - ORDER BY - LIMIT
DCL
管理用户
查询用户
USE mysql;
SELECT * FROM user;创建用户: CREATE USER 用户名主机名 IDENTIFIED BY 密码;
修改用户密码 ALTER USER 用户名主机名 IDENTIFIED WITH mysql_native_password BY 新密码;
删除用户 DROP USER 用户名主机名;
例子
-- 创建用户test只能在当前主机localhost访问
create user testlocalhost identified by 123456;
-- 创建用户test能在任意主机访问
create user test% identified by 123456;
create user test identified by 123456;
-- 修改密码
alter user testlocalhost identified with mysql_native_password by 1234;
-- 删除用户
drop user testlocalhost;注意事项
主机名可以使用 % 通配
权限控制
常用权限
权限说明ALL, ALL PRIVILEGES所有权限SELECT查询数据INSERT插入数据UPDATE修改数据DELETE删除数据ALTER修改表DROP删除数据库/表/视图CREATE创建数据库/表
更多权限请看权限一览表
查询权限 SHOW GRANTS FOR 用户名主机名;
授予权限 GRANT 权限列表 ON 数据库名.表名 TO 用户名主机名;
撤销权限 REVOKE 权限列表 ON 数据库名.表名 FROM 用户名主机名;
注意事项
多个权限用逗号分隔授权时数据库名和表名可以用 * 进行通配代表所有
函数
字符串函数数值函数日期函数流程函数
字符串函数
常用函数
函数功能CONCAT(s1, s2, …, sn)字符串拼接将s1, s2, …, sn拼接成一个字符串LOWER(str)将字符串全部转为小写UPPER(str)将字符串全部转为大写LPAD(str, n, pad)左填充用字符串pad对str的左边进行填充达到n个字符串长度RPAD(str, n, pad)右填充用字符串pad对str的右边进行填充达到n个字符串长度TRIM(str)去掉字符串头部和尾部的空格SUBSTRING(str, start, len)返回从字符串str从start位置起的len个长度的字符串REPLACE(column, source, replace)替换字符串
使用示例
-- 拼接
SELECT CONCAT(Hello, World);
-- 小写
SELECT LOWER(Hello);
-- 大写
SELECT UPPER(Hello);
-- 左填充
SELECT LPAD(01, 5, -);
-- 右填充
SELECT RPAD(01, 5, -);
-- 去除空格
SELECT TRIM( Hello World );
-- 切片起始索引为1
SELECT SUBSTRING(Hello World, 1, 5);数值函数
常见函数
函数功能CEIL(x)向上取整FLOOR(x)向下取整MOD(x, y)返回x/y的模RAND()返回0~1内的随机数ROUND(x, y)求参数x的四舍五入值保留y位小数
日期函数
常用函数
函数功能CURDATE()返回当前日期CURTIME()返回当前时间NOW()返回当前日期和时间YEAR(date)获取指定date的年份MONTH(date)获取指定date的月份DAY(date)获取指定date的日期DATE_ADD(date, INTERVAL expr type)返回一个日期/时间值加上一个时间间隔expr后的时间值DATEDIFF(date1, date2)返回起始时间date1和结束时间date2之间的天数
例子
-- DATE_ADD
SELECT DATE_ADD(NOW(), INTERVAL 70 YEAR);流程函数
常用函数
函数功能IF(value, t, f)如果value为true则返回t否则返回fIFNULL(value1, value2)如果value1不为空返回value1否则返回value2CASE WHEN [ val1 ] THEN [ res1 ] … ELSE [ default ] END如果val1为true返回res1… 否则返回default默认值CASE [ expr ] WHEN [ val1 ] THEN [ res1 ] … ELSE [ default ] END如果expr的值等于val1返回res1… 否则返回default默认值
例子
selectname,(case when age 30 then 中年 else 青年 end)
from employee;
selectname,(case workaddress when 北京市 then 一线城市 when 上海市 then 一线城市 else 二线城市 end) as 工作地址
from employee;约束
分类
约束描述关键字非空约束限制该字段的数据不能为nullNOT NULL唯一约束保证该字段的所有数据都是唯一、不重复的UNIQUE主键约束主键是一行数据的唯一标识要求非空且唯一PRIMARY KEY默认约束保存数据时如果未指定该字段的值则采用默认值DEFAULT检查约束8.0.1版本后保证字段值满足某一个条件CHECK外键约束用来让两张图的数据之间建立连接保证数据的一致性和完整性FOREIGN KEY
约束是作用于表中字段上的可以再创建表/修改表的时候添加约束。
常用约束
约束条件关键字主键PRIMARY KEY自动增长AUTO_INCREMENT不为空NOT NULL唯一UNIQUE逻辑条件CHECK默认值DEFAULT
例子
create table user(id int primary key auto_increment,name varchar(10) not null unique,age int check(age 0 and age 120),status char(1) default 1,gender char(1)
);外键约束
添加外键
CREATE TABLE 表名(字段名 字段类型,...[CONSTRAINT] [外键名称] FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名)
);
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表(主表列名);-- 例子
alter table emp add constraint fk_emp_dept_id foreign key(dept_id) references dept(id);删除外键 ALTER TABLE 表名 DROP FOREIGN KEY 外键名;
删除/更新行为
行为说明NO ACTION当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则不允许删除/更新与RESTRICT一致RESTRICT当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则不允许删除/更新与NO ACTION一致CASCADE当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则也删除/更新外键在子表中的记录SET NULL当在父表中删除/更新对应记录时首先检查该记录是否有对应外键如果有则设置子表中该外键值为null要求该外键允许为nullSET DEFAULT父表有变更时子表将外键设为一个默认值Innodb不支持
更改删除/更新行为 ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名(主表字段名) ON UPDATE 行为 ON DELETE 行为;
多表查询
多表关系
一对多多对一多对多一对一
一对多
案例部门与员工 关系一个部门对应多个员工一个员工对应一个部门 实现在多的一方建立外键指向一的一方的主键
多对多
案例学生与课程 关系一个学生可以选多门课程一门课程也可以供多个学生选修 实现建立第三张中间表中间表至少包含两个外键分别关联两方主键
一对一
案例用户与用户详情 关系一对一关系多用于单表拆分将一张表的基础字段放在一张表中其他详情字段放在另一张表中以提升操作效率 实现在任意一方加入外键关联另外一方的主键并且设置外键为唯一的UNIQUE
查询
合并查询笛卡尔积会展示所有组合结果 select * from employee, dept; 笛卡尔积两个集合A集合和B集合的所有组合情况在多表查询时需要消除无效的笛卡尔积 消除无效笛卡尔积 select * from employee, dept where employee.dept dept.id;
内连接查询
内连接查询的是两张表交集的部分
隐式内连接 SELECT 字段列表 FROM 表1, 表2 WHERE 条件 ...;
显式内连接 SELECT 字段列表 FROM 表1 [ INNER ] JOIN 表2 ON 连接条件 ...;
显式性能比隐式高
例子
-- 查询员工姓名及关联的部门的名称
-- 隐式
select e.name, d.name from employee as e, dept as d where e.dept d.id;
-- 显式
select e.name, d.name from employee as e inner join dept as d on e.dept d.id;外连接查询
左外连接 查询左表所有数据以及两张表交集部分数据 SELECT 字段列表 FROM 表1 LEFT [ OUTER ] JOIN 表2 ON 条件 ...; 相当于查询表1的所有数据包含表1和表2交集部分数据
右外连接 查询右表所有数据以及两张表交集部分数据 SELECT 字段列表 FROM 表1 RIGHT [ OUTER ] JOIN 表2 ON 条件 ...;
例子
-- 左
select e.*, d.name from employee as e left outer join dept as d on e.dept d.id;
select d.name, e.* from dept d left outer join emp e on e.dept d.id; -- 这条语句与下面的语句效果一样
-- 右
select d.name, e.* from employee as e right outer join dept as d on e.dept d.id;左连接可以查询到没有dept的employee右连接可以查询到没有employee的dept
自连接查询
当前表与自身的连接查询自连接必须使用表别名
语法 SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ...;
自连接查询可以是内连接查询也可以是外连接查询
例子
-- 查询员工及其所属领导的名字
select a.name, b.name from employee a, employee b where a.manager b.id;
-- 没有领导的也查询出来
select a.name, b.name from employee a left join employee b on a.manager b.id;联合查询 union, union all
把多次查询的结果合并形成一个新的查询集
语法
SELECT 字段列表 FROM 表A ...
UNION [ALL]
SELECT 字段列表 FROM 表B ...注意事项
UNION ALL 会有重复结果UNION 不会联合查询比使用or效率高不会使索引失效
子查询
SQL语句中嵌套SELECT语句称谓嵌套查询又称子查询。 SELECT * FROM t1 WHERE column1 ( SELECT column1 FROM t2); 子查询外部的语句可以是 INSERT / UPDATE / DELETE / SELECT 的任何一个
根据子查询结果可以分为
标量子查询子查询结果为单个值列子查询子查询结果为一列行子查询子查询结果为一行表子查询子查询结果为多行多列
根据子查询位置可分为
WHERE 之后FROM 之后SELECT 之后
标量子查询
子查询返回的结果是单个值数字、字符串、日期等。 常用操作符-
例子
-- 查询销售部所有员工
select id from dept where name 销售部;
-- 根据销售部部门ID查询员工信息
select * from employee where dept 4;
-- 合并子查询
select * from employee where dept (select id from dept where name 销售部);-- 查询xxx入职之后的员工信息
select * from employee where entrydate (select entrydate from employee where name xxx);列子查询
返回的结果是一列可以是多行。
常用操作符
操作符描述IN在指定的集合范围内多选一NOT IN不在指定的集合范围内ANY子查询返回列表中有任意一个满足即可SOME与ANY等同使用SOME的地方都可以使用ANYALL子查询返回列表的所有值都必须满足
例子
-- 查询销售部和市场部的所有员工信息
select * from employee where dept in (select id from dept where name 销售部 or name 市场部);
-- 查询比财务部所有人工资都高的员工信息
select * from employee where salary all(select salary from employee where dept (select id from dept where name 财务部));
-- 查询比研发部任意一人工资高的员工信息
select * from employee where salary any (select salary from employee where dept (select id from dept where name 研发部));行子查询
返回的结果是一行可以是多列。 常用操作符, , , IN, NOT IN
例子
-- 查询与xxx的薪资及直属领导相同的员工信息
select * from employee where (salary, manager) (12500, 1);
select * from employee where (salary, manager) (select salary, manager from employee where name xxx);表子查询
返回的结果是多行多列 常用操作符IN
例子
-- 查询与xxx1xxx2的职位和薪资相同的员工
select * from employee where (job, salary) in (select job, salary from employee where name xxx1 or name xxx2);
-- 查询入职日期是2006-01-01之后的员工及其部门信息
select e.*, d.* from (select * from employee where entrydate 2006-01-01) as e left join dept as d on e.dept d.id;事务
事务是一组操作的集合事务会把所有操作作为一个整体一起向系统提交或撤销操作请求即这些操作要么同时成功要么同时失败。
基本操作
-- 1. 查询张三账户余额
select * from account where name 张三;
-- 2. 将张三账户余额-1000
update account set money money - 1000 where name 张三;
-- 此语句出错后张三钱减少但是李四钱没有增加
模拟sql语句错误
-- 3. 将李四账户余额1000
update account set money money 1000 where name 李四;-- 查看事务提交方式
SELECT AUTOCOMMIT;
-- 设置事务提交方式1为自动提交0为手动提交该设置只对当前会话有效
SET AUTOCOMMIT 0;
-- 提交事务
COMMIT;
-- 回滚事务
ROLLBACK;-- 设置手动提交后上面代码改为
select * from account where name 张三;
update account set money money - 1000 where name 张三;
update account set money money 1000 where name 李四;
commit;操作方式二
开启事务 START TRANSACTION 或 BEGIN TRANSACTION; 提交事务 COMMIT; 回滚事务 ROLLBACK;
操作实例
start transaction;
select * from account where name 张三;
update account set money money - 1000 where name 张三;
update account set money money 1000 where name 李四;
commit;四大特性ACID
原子性(Atomicity)事务是不可分割的最小操作但愿要么全部成功要么全部失败一致性(Consistency)事务完成时必须使所有数据都保持一致状态隔离性(Isolation)数据库系统提供的隔离机制保证事务在不受外部并发操作影响的独立环境下运行持久性(Durability)事务一旦提交或回滚它对数据库中的数据的改变就是永久的
并发事务
问题描述脏读一个事务读到另一个事务还没提交的数据不可重复读一个事务先后读取同一条记录但两次读取的数据不同幻读一个事务按照条件查询数据时没有对应的数据行但是再插入数据时又发现这行数据已经存在 这三个问题的详细演示https://www.bilibili.com/video/BV1Kr4y1i7ru?p55cd 并发事务隔离级别
隔离级别脏读不可重复读幻读Read uncommitted√√√Read committed×√√Repeatable Read(默认)××√Serializable×××
√表示在当前隔离级别下该问题会出现Serializable 性能最低Read uncommitted 性能最高数据安全性最差
查看事务隔离级别 SELECT TRANSACTION_ISOLATION; 设置事务隔离级别 SET [ SESSION | GLOBAL ] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE }; SESSION 是会话级别表示只针对当前会话有效GLOBAL 表示对所有会话有效
进阶篇
存储引擎
MySQL体系结构 存储引擎就是存储数据、建立索引、更新/查询数据等技术的实现方式。存储引擎是基于表而不是基于库的所以存储引擎也可以被称为表引擎。 默认存储引擎是InnoDB。
相关操作
-- 查询建表语句
show create table account;
-- 建表时指定存储引擎
CREATE TABLE 表名(...
) ENGINEINNODB;
-- 查看当前数据库支持的存储引擎
show engines;InnoDB
InnoDB 是一种兼顾高可靠性和高性能的通用存储引擎在 MySQL 5.5 之后InnoDB 是默认的 MySQL 引擎。
特点
DML 操作遵循 ACID 模型支持事务行级锁提高并发访问性能支持外键约束保证数据的完整性和正确性
文件
xxx.ibd: xxx代表表名InnoDB 引擎的每张表都会对应这样一个表空间文件存储该表的表结构frm、sdi、数据和索引。
参数innodb_file_per_table决定多张表共享一个表空间还是每张表对应一个表空间
知识点
查看 Mysql 变量 show variables like innodb_file_per_table;
从idb文件提取表结构数据 在cmd运行 ibd2sdi xxx.ibd
InnoDB 逻辑存储结构
MyISAM
MyISAM 是 MySQL 早期的默认存储引擎。
特点
不支持事务不支持外键支持表锁不支持行锁访问速度快
文件
xxx.sdi: 存储表结构信息xxx.MYD: 存储数据xxx.MYI: 存储索引
Memory
Memory 引擎的表数据是存储在内存中的受硬件问题、断电问题的影响只能将这些表作为临时表或缓存使用。
特点
存放在内存中速度快hash索引默认
文件
xxx.sdi: 存储表结构信息
存储引擎特点
特点InnoDBMyISAMMemory存储限制64TB有有事务安全支持--锁机制行锁表锁表锁Btree索引支持支持支持Hash索引--支持全文索引支持5.6版本之后支持-空间使用高低N/A内存使用高低中等批量插入速度低高高支持外键支持--
存储引擎的选择
在选择存储引擎时应该根据应用系统的特点选择合适的存储引擎。对于复杂的应用系统还可以根据实际情况选择多种存储引擎进行组合。
InnoDB: 如果应用对事物的完整性有比较高的要求在并发条件下要求数据的一致性数据操作除了插入和查询之外还包含很多的更新、删除操作则 InnoDB 是比较合适的选择MyISAM: 如果应用是以读操作和插入操作为主只有很少的更新和删除操作并且对事务的完整性、并发性要求不高那这个存储引擎是非常合适的。Memory: 将所有数据保存在内存中访问速度快通常用于临时表及缓存。Memory 的缺陷是对表的大小有限制太大的表无法缓存在内存中而且无法保障数据的安全性
电商中的足迹和评论适合使用 MyISAM 引擎缓存适合使用 Memory 引擎。
性能分析
查看执行频次
查看当前数据库的 INSERT, UPDATE, DELETE, SELECT 访问频次 SHOW GLOBAL STATUS LIKE Com_______; 或者 SHOW SESSION STATUS LIKE Com_______; 例show global status like Com_______
慢查询日志
慢查询日志记录了所有执行时间超过指定参数long_query_time单位秒默认10秒的所有SQL语句的日志。 MySQL的慢查询日志默认没有开启需要在MySQL的配置文件/etc/my.cnf中配置如下信息 # 开启慢查询日志开关 slow_query_log1 # 设置慢查询日志的时间为2秒SQL语句执行时间超过2秒就会视为慢查询记录慢查询日志 long_query_time2 更改后记得重启MySQL服务日志文件位置/var/lib/mysql/localhost-slow.log
查看慢查询日志开关状态 show variables like slow_query_log;
profile
show profile 能在做SQL优化时帮我们了解时间都耗费在哪里。通过 have_profiling 参数能看到当前 MySQL 是否支持 profile 操作 SELECT have_profiling; profiling 默认关闭可以通过set语句在session/global级别开启 profiling SET profiling 1; 查看所有语句的耗时 show profiles; 查看指定query_id的SQL语句各个阶段的耗时 show profile for query query_id; 查看指定query_id的SQL语句CPU的使用情况 show profile cpu for query query_id;
explain
EXPLAIN 或者 DESC 命令获取 MySQL 如何执行 SELECT 语句的信息包括在 SELECT 语句执行过程中表如何连接和连接的顺序。 语法 # 直接在select语句之前加上关键字 explain / desc EXPLAIN SELECT 字段列表 FROM 表名 HWERE 条件;
EXPLAIN 各字段含义
idselect 查询的序列号表示查询中执行 select 子句或者操作表的顺序id相同执行顺序从上到下id不同值越大越先执行select_type表示 SELECT 的类型常见取值有 SIMPLE简单表即不适用表连接或者子查询、PRIMARY主查询即外层的查询、UNIONUNION中的第二个或者后面的查询语句、SUBQUERYSELECT/WHERE之后包含了子查询等type表示连接类型性能由好到差的连接类型为 NULL、system、const、eq_ref、ref、range、index、allpossible_key可能应用在这张表上的索引一个或多个Key实际使用的索引如果为 NULL则没有使用索引Key_len表示索引中使用的字节数该值为索引字段最大可能长度并非实际使用长度在不损失精确性的前提下长度越短越好rowsMySQL认为必须要执行的行数在InnoDB引擎的表中是一个估计值可能并不总是准确的filtered表示返回结果的行数占需读取行数的百分比filtered的值越大越好
索引
索引是帮助 MySQL 高效获取数据的数据结构有序。在数据之外数据库系统还维护着满足特定查找算法的数据结构这些数据结构以某种方式引用指向数据这样就可以在这些数据结构上实现高级查询算法这种数据结构就是索引。
优缺点
优点
提高数据检索效率降低数据库的IO成本通过索引列对数据进行排序降低数据排序的成本降低CPU的消耗
缺点
索引列也是要占用空间的索引大大提高了查询效率但降低了更新的速度比如 INSERT、UPDATE、DELETE
索引结构
索引结构描述BTree最常见的索引类型大部分引擎都支持B树索引Hash底层数据结构是用哈希表实现只有精确匹配索引列的查询才有效不支持范围查询R-Tree(空间索引)空间索引是 MyISAM 引擎的一个特殊索引类型主要用于地理空间数据类型通常使用较少Full-Text(全文索引)是一种通过建立倒排索引快速匹配文档的方式类似于 Lucene, Solr, ES
索引InnoDBMyISAMMemoryBTree索引支持支持支持Hash索引不支持不支持支持R-Tree索引不支持支持不支持Full-text5.6版本后支持支持不支持
B-Tree 二叉树的缺点可以用红黑树来解决
红黑树也存在大数据量情况下层级较深检索速度慢的问题。
为了解决上述问题可以使用 B-Tree 结构。 B-Tree (多路平衡查找树) 以一棵最大度数max-degree指一个节点的子节点个数为55阶的 b-tree 为例每个节点最多存储4个key5个指针 B-Tree 的数据插入过程动画参照https://www.bilibili.com/video/BV1Kr4y1i7ru?p68 演示地址https://www.cs.usfca.edu/~galles/visualization/BTree.html BTree
结构图 演示地址https://www.cs.usfca.edu/~galles/visualization/BPlusTree.html 与 B-Tree 的区别
所有的数据都会出现在叶子节点叶子节点形成一个单向链表
MySQL 索引数据结构对经典的 BTree 进行了优化。在原 BTree 的基础上增加一个指向相邻叶子节点的链表指针就形成了带有顺序指针的 BTree提高区间访问的性能。 Hash
哈希索引就是采用一定的hash算法将键值换算成新的hash值映射到对应的槽位上然后存储在hash表中。 如果两个或多个键值映射到一个相同的槽位上他们就产生了hash冲突也称为hash碰撞可以通过链表来解决。 特点
Hash索引只能用于对等比较、in不支持范围查询betwwn、、、…无法利用索引完成排序操作查询效率高通常只需要一次检索就可以了效率通常要高于 BTree 索引
存储引擎支持
MemoryInnoDB: 具有自适应hash功能hash索引是存储引擎根据 BTree 索引在指定条件下自动构建的
面试题
为什么 InnoDB 存储引擎选择使用 BTree 索引结构
相对于二叉树层级更少搜索效率高对于 B-Tree无论是叶子节点还是非叶子节点都会保存数据这样导致一页中存储的键值减少指针也跟着减少要同样保存大量数据只能增加树的高度导致性能降低相对于 Hash 索引BTree 支持范围匹配及排序操作
索引分类
分类含义特点关键字主键索引针对于表中主键创建的索引默认自动创建只能有一个PRIMARY唯一索引避免同一个表中某数据列中的值重复可以有多个UNIQUE常规索引快速定位特定数据可以有多个全文索引全文索引查找的是文本中的关键词而不是比较索引中的值可以有多个FULLTEXT
在 InnoDB 存储引擎中根据索引的存储形式又可以分为以下两种
分类含义特点聚集索引(Clustered Index)将数据存储与索引放一块索引结构的叶子节点保存了行数据必须有而且只有一个二级索引(Secondary Index)将数据与索引分开存储索引结构的叶子节点关联的是对应的主键可以存在多个
演示图 聚集索引选取规则
如果存在主键主键索引就是聚集索引如果不存在主键将使用第一个唯一(UNIQUE)索引作为聚集索引如果表没有主键或没有合适的唯一索引则 InnoDB 会自动生成一个 rowid 作为隐藏的聚集索引
思考题
1. 以下 SQL 语句哪个执行效率高为什么
select * from user where id 10;
select * from user where name Arm;
-- 备注id为主键name字段创建的有索引答第一条语句因为第二条需要回表查询相当于两个步骤。
2. InnoDB 主键索引的 BTree 高度为多少
答假设一行数据大小为1k一页中可以存储16行这样的数据。InnoDB 的指针占用6个字节的空间主键假设为bigint占用字节数为8. 可得公式n * 8 (n 1) * 6 16 * 1024其中 8 表示 bigint 占用的字节数n 表示当前节点存储的key的数量(n 1) 表示指针数量比key多一个。算出n约为1170。
如果树的高度为2那么他能存储的数据量大概为1171 * 16 18736 如果树的高度为3那么他能存储的数据量大概为1171 * 1171 * 16 21939856。
另外如果有成千上万的数据那么就要考虑分表涉及运维篇知识。
语法
创建索引 CREATE [ UNIQUE | FULLTEXT ] INDEX index_name ON table_name (index_col_name, ...); 如果不加 CREATE 后面不加索引类型参数则创建的是常规索引
查看索引 SHOW INDEX FROM table_name;
删除索引 DROP INDEX index_name ON table_name;
案例
-- name字段为姓名字段该字段的值可能会重复为该字段创建索引
create index idx_user_name on tb_user(name);
-- phone手机号字段的值非空且唯一为该字段创建唯一索引
create unique index idx_user_phone on tb_user (phone);
-- 为profession, age, status创建联合索引
create index idx_user_pro_age_stat on tb_user(profession, age, status);
-- 为email建立合适的索引来提升查询效率
create index idx_user_email on tb_user(email);-- 删除索引
drop index idx_user_email on tb_user;使用规则
最左前缀法则
如果索引关联了多列联合索引要遵守最左前缀法则最左前缀法则指的是查询从索引的最左列开始并且不跳过索引中的列。 如果跳跃某一列索引将部分失效后面的字段索引失效。
联合索引中出现范围查询, 范围查询右侧的列索引失效。可以用或者来规避索引失效问题。
索引失效情况
在索引列上进行运算操作索引将失效。如explain select * from tb_user where substring(phone, 10, 2) 15;字符串类型字段使用时不加引号索引将失效。如explain select * from tb_user where phone 17799990015;此处phone的值没有加引号模糊查询中如果仅仅是尾部模糊匹配索引不会是失效如果是头部模糊匹配索引失效。如explain select * from tb_user where profession like %工程;前后都有 % 也会失效。用 or 分割开的条件如果 or 其中一个条件的列没有索引那么涉及的索引都不会被用到。如果 MySQL 评估使用索引比全表更慢则不使用索引。
SQL 提示
是优化数据库的一个重要手段简单来说就是在SQL语句中加入一些人为的提示来达到优化操作的目的。
例如使用索引 explain select * from tb_user use index(idx_user_pro) where profession软件工程; 不使用哪个索引 explain select * from tb_user ignore index(idx_user_pro) where profession软件工程; 必须使用哪个索引 explain select * from tb_user force index(idx_user_pro) where profession软件工程;
use 是建议实际使用哪个索引 MySQL 还会自己权衡运行速度去更改force就是无论如何都强制使用该索引。
覆盖索引回表查询
尽量使用覆盖索引查询使用了索引并且需要返回的列在该索引中已经全部能找到减少 select *。
explain 中 extra 字段含义 using index condition查找使用了索引但是需要回表查询数据 using where; using index;查找使用了索引但是需要的数据都在索引列中能找到所以不需要回表查询
如果在聚集索引中直接能找到对应的行则直接返回行数据只需要一次查询哪怕是select *如果在辅助索引中找聚集索引如select id, name from xxx where namexxx;也只需要通过辅助索引(name)查找到对应的id返回name和name索引对应的id即可只需要一次查询如果是通过辅助索引查找其他字段则需要回表查询如select id, name, gender from xxx where namexxx;
所以尽量不要用select *容易出现回表查询降低效率除非有联合索引包含了所有字段
面试题一张表有四个字段id, username, password, status由于数据量大需要对以下SQL语句进行优化该如何进行才是最优方案 select id, username, password from tb_user where usernameitcast;
解给username和password字段建立联合索引则不需要回表查询直接覆盖索引
前缀索引
当字段类型为字符串varchar, text等时有时候需要索引很长的字符串这会让索引变得很大查询时浪费大量的磁盘IO影响查询效率此时可以只降字符串的一部分前缀建立索引这样可以大大节约索引空间从而提高索引效率。
语法create index idx_xxxx on table_name(columnn(n)); 前缀长度可以根据索引的选择性来决定而选择性是指不重复的索引值基数和数据表的记录总数的比值索引选择性越高则查询效率越高唯一索引的选择性是1这是最好的索引选择性性能也是最好的。 求选择性公式
select count(distinct email) / count(*) from tb_user;
select count(distinct substring(email, 1, 5)) / count(*) from tb_user;show index 里面的sub_part可以看到接取的长度
单列索引联合索引
单列索引即一个索引只包含单个列 联合索引即一个索引包含了多个列 在业务场景中如果存在多个查询条件考虑针对于查询字段建立索引时建议建立联合索引而非单列索引。
单列索引情况 explain select id, phone, name from tb_user where phone 17799990010 and name 韩信; 这句只会用到phone索引字段
注意事项
多条件联合查询时MySQL优化器会评估哪个字段的索引效率更高会选择该索引完成本次查询
设计原则
针对于数据量较大且查询比较频繁的表建立索引针对于常作为查询条件where、排序order by、分组group by操作的字段建立索引尽量选择区分度高的列作为索引尽量建立唯一索引区分度越高使用索引的效率越高如果是字符串类型的字段字段长度较长可以针对于字段的特点建立前缀索引尽量使用联合索引减少单列索引查询时联合索引很多时候可以覆盖索引节省存储空间避免回表提高查询效率要控制索引的数量索引并不是多多益善索引越多维护索引结构的代价就越大会影响增删改的效率如果索引列不能存储NULL值请在创建表时使用NOT NULL约束它。当优化器知道每列是否包含NULL值时它可以更好地确定哪个索引最有效地用于查询
SQL 优化
插入数据
普通插入
采用批量插入一次插入的数据不建议超过1000条手动提交事务主键顺序插入
大批量插入 如果一次性需要插入大批量数据使用insert语句插入性能较低此时可以使用MySQL数据库提供的load指令插入。
# 客户端连接服务端时加上参数 --local-infile这一行在bash/cmd界面输入
mysql --local-infile -u root -p
# 设置全局参数local_infile为1开启从本地加载文件导入数据的开关
set global local_infile 1;
select local_infile;
# 执行load指令将准备好的数据加载到表结构中
load data local infile /root/sql1.log into table tb_user fields terminated by , lines terminated by \n;主键优化
数据组织方式在InnoDB存储引擎中表数据都是根据主键顺序组织存放的这种存储方式的表称为索引组织表Index organized table, IOT
页分裂页可以为空也可以填充一般也可以填充100%每个页包含了2-N行数据如果一行数据过大会行溢出根据主键排列。 页合并当删除一行记录时实际上记录并没有被物理删除只是记录被标记flaged为删除并且它的空间变得允许被其他记录声明使用。当页中删除的记录到达 MERGE_THRESHOLD默认为页的50%InnoDB会开始寻找最靠近的页前后看看是否可以将这两个页合并以优化空间使用。
MERGE_THRESHOLD合并页的阈值可以自己设置在创建表或创建索引时指定 文字说明不够清晰明了具体可以看视频里的PPT演示过程https://www.bilibili.com/video/BV1Kr4y1i7ru?p90 主键设计原则
满足业务需求的情况下尽量降低主键的长度插入数据时尽量选择顺序插入选择使用 AUTO_INCREMENT 自增主键尽量不要使用 UUID 做主键或者是其他的自然主键如身份证号业务操作时避免对主键的修改
order by优化
Using filesort通过表的索引或全表扫描读取满足条件的数据行然后在排序缓冲区 sort buffer 中完成排序操作所有不是通过索引直接返回排序结果的排序都叫 FileSort 排序Using index通过有序索引顺序扫描直接返回有序数据这种情况即为 using index不需要额外排序操作效率高
如果order by字段全部使用升序排序或者降序排序则都会走索引但是如果一个字段升序排序另一个字段降序排序则不会走索引explain的extra信息显示的是Using index, Using filesort如果要优化掉Using filesort则需要另外再创建一个索引如create index idx_user_age_phone_ad on tb_user(age asc, phone desc);此时使用select id, age, phone from tb_user order by age asc, phone desc;会全部走索引
总结
根据排序字段建立合适的索引多字段排序时也遵循最左前缀法则尽量使用覆盖索引多字段排序一个升序一个降序此时需要注意联合索引在创建时的规则ASC/DESC如果不可避免出现filesort大数据量排序时可以适当增大排序缓冲区大小 sort_buffer_size默认256k
group by优化
在分组操作时可以通过索引来提高效率分组操作时索引的使用也是满足最左前缀法则的
如索引为idx_user_pro_age_stat则句式可以是select ... where profession order by age这样也符合最左前缀法则
limit优化
常见的问题如limit 2000000, 10此时需要 MySQL 排序前2000000条记录但仅仅返回2000000 - 2000010的记录其他记录丢弃查询排序的代价非常大。 优化方案一般分页查询时通过创建覆盖索引能够比较好地提高性能可以通过覆盖索引加子查询形式进行优化
例如
-- 此语句耗时很长
select * from tb_sku limit 9000000, 10;
-- 通过覆盖索引加快速度直接通过主键索引进行排序及查询
select id from tb_sku order by id limit 9000000, 10;
-- 下面的语句是错误的因为 MySQL 不支持 in 里面使用 limit
-- select * from tb_sku where id in (select id from tb_sku order by id limit 9000000, 10);
-- 通过连表查询即可实现第一句的效果并且能达到第二句的速度
select * from tb_sku as s, (select id from tb_sku order by id limit 9000000, 10) as a where s.id a.id;count优化
MyISAM 引擎把一个表的总行数存在了磁盘上因此执行 count(*) 的时候会直接返回这个数效率很高前提是不适用where InnoDB 在执行 count(*) 时需要把数据一行一行地从引擎里面读出来然后累计计数。 优化方案自己计数如创建key-value表存储在内存或硬盘或者是用redis
count的几种用法
如果count函数的参数count里面写的那个字段不是NULL字段值不为NULL累计值就加一最后返回累计值用法count(*)、count(主键)、count(字段)、count(1)count(主键)跟count(*)一样因为主键不能为空count(字段)只计算字段值不为NULL的行count(1)引擎会为每行添加一个1然后就count这个1返回结果也跟count(*)一样count(null)返回0
各种用法的性能
count(主键)InnoDB引擎会遍历整张表把每行的主键id值都取出来返回给服务层服务层拿到主键后直接按行进行累加主键不可能为空count(字段)没有not null约束的话InnoDB引擎会遍历整张表把每一行的字段值都取出来返回给服务层服务层判断是否为null不为null计数累加有not null约束的话InnoDB引擎会遍历整张表把每一行的字段值都取出来返回给服务层直接按行进行累加count(1)InnoDB 引擎遍历整张表但不取值。服务层对于返回的每一层放一个数字 1 进去直接按行进行累加count(*)InnoDB 引擎并不会把全部字段取出来而是专门做了优化不取值服务层直接按行进行累加
按效率排序count(字段) count(主键) count(1) count(*)所以尽量使用 count(*)
update优化避免行锁升级为表锁
InnoDB 的行锁是针对索引加的锁不是针对记录加的锁并且该索引不能失效否则会从行锁升级为表锁。
如以下两条语句 update student set no 123 where id 1;这句由于id有主键索引所以只会锁这一行 update student set no 123 where name test;这句由于name没有索引所以会把整张表都锁住进行数据更新解决方法是给name字段添加索引
数据类型
整型
类型名称取值范围大小TINYINT-128〜1271个字节SMALLINT-32768〜327672个宇节MEDIUMINT-8388608〜83886073个字节INT (INTEGHR)-2147483648〜21474836474个字节BIGINT-9223372036854775808〜92233720368547758078个字节
无符号在数据类型后加 unsigned 关键字。
浮点型
类型名称说明存储需求FLOAT单精度浮点数4 个字节DOUBLE双精度浮点数8 个字节DECIMAL (M, D)DEC压缩的“严格”定点数M2 个字节
日期和时间
类型名称日期格式日期范围存储需求YEARYYYY1901 ~ 21551 个字节TIMEHH:MM:SS-838:59:59 ~ 838:59:593 个字节DATEYYYY-MM-DD1000-01-01 ~ 9999-12-33 个字节DATETIMEYYYY-MM-DD HH:MM:SS1000-01-01 00:00:00 ~ 9999-12-31 23:59:598 个字节TIMESTAMPYYYY-MM-DD HH:MM:SS1980-01-01 00:00:01 UTC ~ 2040-01-19 03:14:07 UTC4 个字节
字符串
类型名称说明存储需求CHAR(M)固定长度非二进制字符串M 字节1M255VARCHAR(M)变长非二进制字符串L1字节在此L M和 1M255TINYTEXT非常小的非二进制字符串L1字节在此L2^8TEXT小的非二进制字符串L2字节在此L2^16MEDIUMTEXT中等大小的非二进制字符串L3字节在此L2^24LONGTEXT大的非二进制字符串L4字节在此L2^32ENUM枚举类型只能有一个枚举字符串值1或2个字节取决于枚举值的数目 (最大值为65535)SET一个设置字符串对象可以有零个或 多个SET成员1、2、3、4或8个字节取决于集合 成员的数量最多64个成员
二进制类型
类型名称说明存储需求BIT(M)位字段类型大约 (M7)/8 字节BINARY(M)固定长度二进制字符串M 字节VARBINARY (M)可变长度二进制字符串M1 字节TINYBLOB (M)非常小的BLOBL1 字节在此L2^8BLOB (M)小 BLOBL2 字节在此L2^16MEDIUMBLOB (M)中等大小的BLOBL3 字节在此L2^24LONGBLOB (M)非常大的BLOBL4 字节在此L2^32
权限一览表 具体权限的作用详见官方文档 GRANT 和 REVOKE 允许的静态权限
PrivilegeGrant Table ColumnContextALL [PRIVILEGES]Synonym for “all privileges”Server administrationALTERAlter_privTablesALTER ROUTINEAlter_routine_privStored routinesCREATECreate_privDatabases, tables, or indexesCREATE ROLECreate_role_privServer administrationCREATE ROUTINECreate_routine_privStored routinesCREATE TABLESPACECreate_tablespace_privServer administrationCREATE TEMPORARY TABLESCreate_tmp_table_privTablesCREATE USERCreate_user_privServer administrationCREATE VIEWCreate_view_privViewsDELETEDelete_privTablesDROPDrop_privDatabases, tables, or viewsDROP ROLEDrop_role_privServer administrationEVENTEvent_privDatabasesEXECUTEExecute_privStored routinesFILEFile_privFile access on server hostGRANT OPTIONGrant_privDatabases, tables, or stored routinesINDEXIndex_privTablesINSERTInsert_privTables or columnsLOCK TABLESLock_tables_privDatabasesPROCESSProcess_privServer administrationPROXYSee proxies_priv tableServer administrationREFERENCESReferences_privDatabases or tablesRELOADReload_privServer administrationREPLICATION CLIENTRepl_client_privServer administrationREPLICATION SLAVERepl_slave_privServer administrationSELECTSelect_privTables or columnsSHOW DATABASESShow_db_privServer administrationSHOW VIEWShow_view_privViewsSHUTDOWNShutdown_privServer administrationSUPERSuper_privServer administrationTRIGGERTrigger_privTablesUPDATEUpdate_privTables or columnsUSAGESynonym for “no privileges”Server administration
GRANT 和 REVOKE 允许的动态权限
PrivilegeContextAPPLICATION_PASSWORD_ADMINDual password administrationAUDIT_ABORT_EXEMPTAllow queries blocked by audit log filterAUDIT_ADMINAudit log administrationAUTHENTICATION_POLICY_ADMINAuthentication administrationBACKUP_ADMINBackup administrationBINLOG_ADMINBackup and Replication administrationBINLOG_ENCRYPTION_ADMINBackup and Replication administrationCLONE_ADMINClone administrationCONNECTION_ADMINServer administrationENCRYPTION_KEY_ADMINServer administrationFIREWALL_ADMINFirewall administrationFIREWALL_EXEMPTFirewall administrationFIREWALL_USERFirewall administrationFLUSH_OPTIMIZER_COSTSServer administrationFLUSH_STATUSServer administrationFLUSH_TABLESServer administrationFLUSH_USER_RESOURCESServer administrationGROUP_REPLICATION_ADMINReplication administrationGROUP_REPLICATION_STREAMReplication administrationINNODB_REDO_LOG_ARCHIVERedo log archiving administrationNDB_STORED_USERNDB ClusterPASSWORDLESS_USER_ADMINAuthentication administrationPERSIST_RO_VARIABLES_ADMINServer administrationREPLICATION_APPLIERPRIVILEGE_CHECKS_USER for a replication channelREPLICATION_SLAVE_ADMINReplication administrationRESOURCE_GROUP_ADMINResource group administrationRESOURCE_GROUP_USERResource group administrationROLE_ADMINServer administrationSESSION_VARIABLES_ADMINServer administrationSET_USER_IDServer administrationSHOW_ROUTINEServer administrationSYSTEM_USERServer administrationSYSTEM_VARIABLES_ADMINServer administrationTABLE_ENCRYPTION_ADMINServer administrationVERSION_TOKEN_ADMINServer administrationXA_RECOVER_ADMINServer administration
图形化界面工具
Workbench(免费): http://dev.mysql.com/downloads/workbench/navicat(收费试用版30天): https://www.navicat.com/en/download/navicat-for-mysqlSequel Pro(开源免费仅支持Mac OS): http://www.sequelpro.com/HeidiSQL(免费): http://www.heidisql.com/phpMyAdmin(免费): https://www.phpmyadmin.net/SQLyog: https://sqlyog.en.softonic.com/
安装
小技巧
在SQL语句之后加上\G会将结果的表格形式转换成行文本形式查看Mysql数据库占用空间
SELECT table_schema Database Name, SUM(data_length index_length) / (1024 * 1024) Database Size in MB
FROM information_schema.TABLES
GROUP BY table_schema;