mysql系列01---通用的语法及分类
通用语法及分类
- DDL: 数据定义语言,用来定义数据库对象(数据库、表、字段)
- DML: 数据操作语言,用来对数据库表中的数据进行增删改
- DQL: 数据查询语言,用来查询数据库中表的记录
- DCL: 数据控制语言,用来创建数据库用户、控制数据库的控制权限
一、DDL(数据定义语言)
1、数据库操作
1.1 创建数据库:CREATE DATABASE [ IF NOT EXISTS ] 数据库名 [ DEFAULT CHARSET 字符集] [COLLATE 排序规则 ];
1.2 删除数据库:DROP DATABASE [ IF EXISTS ] 数据库名;
注意:UTF8字符集长度为3字节,有些符号占4字节,所以推荐用utf8mb4字符集
2、表操作
2.1 查询表结构:DESC 表名;
2.2 查询指定表的建表语句:SHOW CREATE TABLE 表名;
2.3 创建表:
CREATE TABLE 表名(
字段1 字段1类型 [COMMENT 字段1注释],
字段2 字段2类型 [COMMENT 字段2注释],
字段3 字段3类型 [COMMENT 字段3注释],
...
字段n 字段n类型 [COMMENT 字段n注释]
)[ COMMENT 表注释 ];
2.4 添加字段:ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束];
例:ALTER TABLE emp ADD nickname varchar(20) COMMENT '昵称';
2.5 修改数据类型:ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);
2.6 修改字段名和字段类型:ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度) [COMMENT 注释] [约束];
例:将emp表的nickname字段修改为username,类型为varchar(30)ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT '昵称';
2.7 删除字段:ALTER TABLE 表名 DROP 字段名;
2.8 修改表名:ALTER TABLE 表名 RENAME TO 新表名
2.9 删除表:DROP TABLE [IF EXISTS] 表名;
2.10 删除表,并重新创建该表:TRUNCATE TABLE 表名;
二、DML(数据操作语言)
1、插入数据库
方法一:
INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
方法二:
INSERT INTO 表名 (字段名1, 字段名2)
SELECT
值1, 值2 FROM 表名01
2、更新数据库
方法一:直接更新表
UPDATE emp SET name = 'Jack' WHERE id = 1;
方法二:联表更新
update t_sett_readysettledetail a inner join t_stockmanage_deptproductbatchstocktrack b on a.trackcode = b.TrackCode and a.deptid=b.deptid set a.supplierid = b.supplierid ,a.suppliername = b.SupplierName where a.supplierId is null
三、DQL(数据查询语言)
1、语法
SELECT
字段列表
FROM
表名字段
WHERE
条件列表
GROUP BY
分组字段列表
HAVING
分组后的条件列表
ORDER BY
排序字段列表
LIMIT
分页参数
2、条件
比较运算符 | 功能 |
---|---|
> | 大于 |
>= | 大于等于 |
< | 小于 |
<= | 小于等于 |
= | 等于 |
<> 或 != | 不等于 |
BETWEEN … AND … | 在某个范围内(含最小、最大值) |
IN(…) | 在in之后的列表中的值,多选一 |
LIKE 占位符 | 模糊匹配(_匹配单个字符,%匹配任意个字符) |
IS NULL | 是NULL |
逻辑运算符 | 功能 |
---|---|
AND 或 && | 并且(多个条件同时成立) |
OR 或 || | 或者(多个条件任意一个成立) |
NOT 或 ! | 非,不是 |
3、聚合函数
3.1 不分组语法:SELECT 聚合函数(字段列表) FROM 表名;
例:SELECT count(id) from employee where workaddress = "广东省";
3.2 分组的语法:SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组后的过滤条件 ];
3.3 where 和 having 的区别:
- 执行时机不同:where是分组之前进行过滤,不满足where条件不参与分组;having是分组后对结果进行过滤。
- 判断条件不同:where不能对聚合函数进行判断,而having可以。
- 执行顺序:where > 聚合函数 > having
4、分页查询
SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数;
5、DQL执行顺序
FROM -> WHERE -> GROUP BY -> SELECT -> ORDER BY -> LIMIT
四、DCL(数据库控制语言)
-- 创建用户test,能在任意主机访问 create user 'test'@'%' identified by '123456'; create user 'test' identified by '123456'; -- 修改密码 alter user 'test'@'localhost' identified with mysql_native_password by '1234'; -- 删除用户 drop user 'test'@'localhost';
例:在系统对接时,只想给对方开发人员指定用户的访问某个表的权限
CREATE USER 'jsp'@'%' IDENTIFIED BY 'jsp123456'; GRANT SELECT, INSERT, UPDATE, DELETE ON table01 TO 'jsp'@'%';