通用语法及分类
-
DDL: 数据定义语言,用来定义数据库对象(数据库、表、字段)
-
DML: 数据操作语言,用来对数据库表中的数据进行增删改
-
DQL: 数据查询语言,用来查询数据库中表的记录
-
DCL: 数据控制语言,用来创建数据库用户、控制数据库的控制权限
DDL(数据定义语言)
数据定义语言
数据库操作
查询所有数据库: SHOW DATABASES;
查询当前数据库: SELECT DATABASE();
创建数据库: CREATE DATABASE [ IF NOT EXISTS ] 数据库名 [ DEFAULT CHARSET 字符集] [COLLATE 排序规则 ];
删除数据库: DROP DATABASE [ IF EXISTS ] 数据库名;
使用数据库: USE 数据库名;
注意事项
-
UTF8字符集长度为3字节,有些符号占4字节,所以推荐用utf8mb4字符集
表操作
查询当前数据库所有表: SHOW TABLES;
查询表结构: DESC 表名;
查询指定表的建表语句: SHOW CREATE TABLE 表名;
创建表:
CREATE TABLE 表名( 字段1 字段1类型 [COMMENT 字段1注释], 字段2 字段2类型 [COMMENT 字段2注释], 字段3 字段3类型 [COMMENT 字段3注释], ... 字段n 字段n类型 [COMMENT 字段n注释] )[ COMMENT 表注释 ];
最后一个字段后面没有逗号
添加字段: ALTER TABLE 表名 ADD 字段名 类型(长度) [COMMENT 注释] [约束];
例:ALTER TABLE emp ADD nickname varchar(20) COMMENT '昵称';
修改数据类型: ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);
修改字段名和字段类型: ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度) [COMMENT 注释] [约束];
例:将emp表的nickname字段修改为username,类型为varchar(30) ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT '昵称';
删除字段: ALTER TABLE 表名 DROP 字段名;
修改表名: ALTER TABLE 表名 RENAME TO 新表名
删除表: DROP TABLE [IF EXISTS] 表名;
删除表,并重新创建该表: TRUNCATE TABLE 表名;
DML(数据操作语言)
添加数据
指定字段: INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
全部字段: INSERT INTO 表名 VALUES (值1, 值2, ...);
批量添加数据: INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...);
INSERT INTO 表名 VALUES (值1, 值2, ...), (值1, 值2, ...), (值1, 值2, ...);
注意事项
-
字符串和日期类型数据应该包含在引号中
-
插入的数据大小应该在字段的规定范围内
更新和删除数据
修改数据: UPDATE 表名 SET 字段名1 = 值1, 字段名2 = 值2, ... [ WHERE 条件 ];
例: UPDATE emp SET name = 'Jack' WHERE id = 1;
删除数据: DELETE FROM 表名 [ WHERE 条件 ];