MySQL常用语句

1.DDL(数据库定义语言)

数据库

查看所有数据库:SHOW DATABASES;
选择要操作的数据库:USE 数据库名;
创建数据库:CREATE DATABASE 数据库名 CHARACTER SET UTF8;
删除数据库:DROP DATABASE 数据库名;
修改数据库编码格式:ALTER DATABASE 数据库名 CHARACTER SET UTF8;

数据类型

int:整型
double:浮点型,如double(5,2)表示长度最多为5,包括小数点后两位
char:固定长度字符串,如char(24)
varchar:可变长度字符串
date:日期类型,格式yyyy-MM-dd
time:时间类型,格式HH:mm:ss
timestamp:时间戳类型
blob:二进制形式的长文本数据
text:长文本数据

创建表:CREATE TABLE 表名(列名1 列类型1,列名2 列类型2,...);
查看当前数据库中所有表名称:SHOW TABLES;
查看指定表的创建语句:SHOW CREATE TABLE 表名;
查看表结构:DESC 表名;
删除表:DROP TABLE 表名;
修改表:
  添加列:ALTER TABLE 表名 ADD(列名 列类型);
  修改列类型:ALTER TABLE 表名 MODIFY 列名 列类型;
  修改列名:ALTER TABLE 表名 CHANGE 原列名 新列名 列类型;
  删除列:ALTER TABLE 表名 DROP 列名;
  修改表名称:ALTER TABLE 原表名 RENAME TO 新表名;

2.DML(数据库操作语言)

插入数据
INSERT INTO 表名(列名1,列名2,...) VALUES(列值1,列值2,...);

在表名后给出要插入的列名,其他没有指定的列插入null值,插入记录只能插入一行,不可能插入部分;
在values后给出列值,值的顺序和个数必须与前面指定的列对应

INSERT INTO 表名 VALUES(列值1,列值2,...);

没有给出要出入的列,表示插入所有列;
值的个数必须是该表列的个数;
值的顺序,必须与表创建时给出的列的顺序相同

修改数据

UPDATE 表名 SET 列名1=列值1,列名2=列值2,...[WHERE 条件]
条件必须是一个boolean类型的值或表达式,常用运算符有:=,!=,<>,<,>,>=,<=,BETWEEN...AND,IN(...),IS NULL,NOT,OR,AND

删除数据

DELETE FROM 表名 [WHERE 条件];

3.DCL(数据库控制语言)

创建用户

CREATE USER 用户名@IP地址 IDENTIFIED BY '密码';
  用户只能在指定的IP地址上登录
CREATE USET 用户名@'%' IDENTIFIED BY '密码';
  用户可以在任意IP地址上登录

给用户授权

GRANT 权限1,...,权限n ON 数据库.* TO 用户名@IP地址;
  权限有:CREATE , ALTER , DROP , INSERT , UPDATE , DELETE , SELECT ...ALL

撤销授权

REVOKE 权限1,..., 权限n ON 数据库.* FROM 用户名@IP地址;

查看权限

SHOW GRANTS FOR 用户名@IP地址

删除用户

DROP USER 用户名@IP地址

4.DQL(数据库查询语言)

字段(列)控制

查询所有列:SELECT * FROM 表名;
查询指定列:SELECT 列名 FROM 表名;
重复的出现一次:SELECT DISTINCT * FROM 表名;
列运算:SELECT 列名 运算符 FROM 表名;
  数量类型的运算可以做加、减、乘、除
  字符串类型列可以做连续运算
SELECT CONCAT(字符串或者列名,字符串或者列名)FROM 表名;
如果存在null值,做运算时结果还是null,所以要使用
SELECT IFNULL(列名,0)+100 FROM 表名;
  IFNULL(列名,0):如果列中存在null值,那么当成0来运算
给列起别名:SELECT 列名 别名 FROM 表名;

条件控制

条件查询:SELECT 列名1,类名2 FROM 表名 WHERE 条件
模糊查询:SELECT * FROM 表名 WHERE 列名 like '张';
SELECT * FROM 表名 WHERE 列名 like '张%';
  
只匹配一个字符,%可以匹配0-n个字符;只用一个%,可以把出去null值的查询出来

排序

升序:SELECT * FROM 表名 ORDER BY 列名 ASC;
降序:SELECT * FROM 表名 ORDER BY 列名 DESC;
多列作为排序条件:SELECT * FROM 表名 ORDER BY 列名1 ASC,列名2 ASC...;如果列1值相同,则按列2升序排列,后可跟更多条件

聚合函数

COUNT:统计不为null的行数
计算表中所有列不为null的行数:SELECT COUNT(*) FROM 表名;
计算表中指定列不为null的行数:SELECT COUNT(列名) FROM 表名;
MAX:查询最高值
SELECT MAX(列名) FROM 表名;
MIN:查询最小值
SELECT MIN(列名) FROM 表名;
SUM:查询总数
SELECT SUM(列名) FROM 表名;
AVG:查询平均数
SELECT AVG(列名) FROM 表名;

分组查询

查询所有组的记录数
SELECT 列名 ,COUNT() FROM 表名 GROUP BY 列名;
组外查询条件
SELECT 列名 ,COUNT(
) FROM 表名 WHERE 条件 GROUP BY 列名;
组内查询条件
SELECT 列名 , COUNT(*) FROM 表名 GROUP BY 列名 HAVING 条件(聚合函数);

Limit子句(方言)*****

limit用来限定查询结果的起始行,以及总行数。例如:查询起始行为第五行,一共查询3行记录:
SELECT * FROM 表名 LIMIT 4,3;
4表示从第五行开始,3表示一共有3行记录

多表查询
  1. 内连接
    普通的内连接
    前提:要有外键
    关键字: inner join A表.字段 on B表.字段
    隐式的内连接(用得最多)
    不用inner join ... on 关键字
    select * from dept d, emp e where d.did=e.dno;

  2. 外连接
    左外连接(把左表所有的数据查询出来)
    前提:要有外键
    语法: left [outer] join A表.字段 on B表.字段
    select * from dept t1 left join emp t2 on t1.did = t2.dno;

  3. 右外连接
    前提:要有外键
    语法: right [outer] join A表.字段 on B表.字段
    select * from dept t1 right join emp t2 on t1.did = t2.dno;

  4. 子查询
    查询的内容要用另一个查询的结果
    select * from emp where ename > (select * from emp where 条件)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容