通用语法及分类
- 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';
标签:COMMENT,01,数据库,mysql,---,字段,表名,TABLE,字段名 From: https://www.cnblogs.com/zhengwei-cq/p/17510947.html