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行记录
多表查询
内连接
普通的内连接
前提:要有外键
关键字: inner join A表.字段 on B表.字段
隐式的内连接(用得最多)
不用inner join ... on 关键字
select * from dept d, emp e where d.did=e.dno;外连接
左外连接(把左表所有的数据查询出来)
前提:要有外键
语法: left [outer] join A表.字段 on B表.字段
select * from dept t1 left join emp t2 on t1.did = t2.dno;右外连接
前提:要有外键
语法: right [outer] join A表.字段 on B表.字段
select * from dept t1 right join emp t2 on t1.did = t2.dno;子查询
查询的内容要用另一个查询的结果
select * from emp where ename > (select * from emp where 条件)