1.创建数据库 :create database 名称 [charset 字符集 collate 校对规则] ; 如:
drop database if exists `mydb` ; # 若存在就删除
create database `mydb` default charset=utf8 collate=utf8_general_ci ;
2.查看校队规则 :show collation;
3.查看数据库/表 :show databases/tables;
4.显示创建的数据库/表 :show create database/table 数据库名/表名[\G];
5.查看当前使用的数据库 :select database();
6.创建表 :create table 表名(
字段名 数据类型 [该字段约束条件],
字段名 数据类型 [该字段约束条件],
......
)[engine=InnoDB default charset=utf8mb4 collate=utf8mb4_general_ci];
7.删除数据集/表 :drop database/table 名;
8.查看数据表 :describe 表名 ;
或者 desc 表名;
9.修改表名 :alter table 表名 rename 新表名;
或者 rename table 表名 to 新表名;
10.主键约束(非空+唯一) :primary key
外键约束:foreign key...reference...
唯一约束 :unique
非空约束 :not unll
检查约束 :check(条件)
11.添加数据 :insert into 表名(字段名,字段名,字段名...不写默认全部字段) values
(数据,数据,数据),
(数据,数据,数据),
...;
或者 :insert into 表名
set 字段名=值,字段名=值,...;
12.删除数据 :delete from 表名 where 过滤条件;
或者 truncate 表名;
13.更新数据 :update 表名 set 字段名=值,字段名=值...where 过滤条件;
14.查询 :select * from 表名;
select 字段名,字段名,...from 表名;
过滤:where 过滤条件
in(集合)、 between...and(范围)、 is null(空值) 、distinct(排除重复值)、 like '%*%' (模糊查询) 、and(并且)、 or(或者)
15.复制表 :create table 新表名 like 旧表名; (拷贝结构)
create table 新表名 as (select * from 旧表名); (拷贝结构和数据)
insert into 新表名 as (select * from 旧表名); (拷贝数据)
16.聚合函数 :count()返回某列的行数, sum()返回某列的和 avg()返回某列的平均值,max()返回某列的最大值, min()返回某列的最小值, IFNULL(参数,如果为空则改为的值)
17.排序 :order by 字段名 asc/desc;
asc为升序 desc为降序 默认为asc
18.分组 :group by 字段名 having 过滤条件;
19.限制查询结果 :limit a,b;
a代表开始的标号(第一条为0) b代表显示的条数
20.子查询 :select 字段名,(子查询) from 表名;
select * from (子查询);
select * from 表名 where (子查询);
子查询关键字:exists(子查询):只要里面的子查询返回了行,exists的值为真,外部查询就执行。
字段名 (比较运算符如>) all (子查询) :大于子查询里的每一个值。
字段名 (比较运算符如>)some或any (子查询) :大于子查询里的任何值,也就是最小值。
in(子查询) :存在。
21.联合操作 :select * from a
union
select * from b;
将两张表纵向连接起来,但是两张表的字段数必须相同
22.外键约束 :alter table 表名
add constraint 外键名 foreign key (外键字段名) references 外键表名 (主键字段名);
删除外键 :alter table 表名 drop foreign key 外键名
23.联表查询 :内连接 :select * from 表1 [inner] join 表2 [on/where 表1.关系字段=表2.关系字段]; (on是内联前过滤 ,where是产生笛卡尔乘积之后再过滤)
cross join(交叉连接,在MySQL中等价于inner join)
外连接(必须写关联条件) 左外: select * from 表1 left [outer] join 表2 on 表1.关系字段=表2.关系字段;
右外: select * from 表1 right [outer] join 表2 on 表1.关系字段=表2.关系字段;
全外: select * from 表1 full [outer] join 表2; (MySQL不支持,可以用union)
自连接 :select * from 表1 别名1 join 表1 别名2;
24.创建视图 :create view 视图名 as
select语句
查看视图 : ①desc 视图名
②show table statas like '视图名'
③show create view 视图名
修改视图 :create or replace view 视图名 as
select语句
或者 alter view 视图名 as
select语句
25.case when 字段=数据1 then '返回值1' when 字段=数据2 then '返回值2'... else '返回值3’ end [as] 字段别名
例如:select id,name,(case when ismale=1 then '男' when ismale=2 then '女' else '未知性别' end) as 性别 from employee;
26.备份
备份所有数据库:
mysqldump –u 用户名 –p –h 主机名 --all-databases > 备份文件名.sql
备份整个或多个数据库:
mysqldump –u 用户名 –p –h 主机名 --databases db1 db2 db3 … > 备份文件名.sql
备份某个数据库的某些表:
mysqldump –u 用户名 –p –h 主机名 数据库名 表1 表2 表3… > 备份文件名.sql
27.恢复
通过mysqldump,如果使用了"--all-databases"或"--databases"选项,则在备份文件中包含CREATE DATABASE和USE语句,故并不需要指定一个数据库名去恢复备份文件。
mysql –u 用户名 –p < 备份文件.sql
通过mysqldump,如果没有使用"--databases"选项,则备份文件中不包含CREATE DATABASE和USE语句,那么在恢复的时候必须指定数据库。
mysql –u 用户名 –p 数据库名 < 备份文件.sql
28.设置自动创建和自动更新时间(格式是:2018-01-01 00:00:00)
自动创建时间:`create_datetime` timestamp default current_timestamp
自动更新时间:`update_datetime` timestamp default current_timestamp on update current_timestamp
29.修改用户密码
alter user username@localhost identified by 'newpwd';
30.给用户授权
grant all privileges on dbname.* to username@localhost;
flush privileges; # 刷新生效
至此,转载请注明出处。