1. SQL通用语法
1. SQL语句可以单行或多行书写,以分号结尾。
2. SQL语句可以使用空格/缩进来增强语句的可读性。
3. MySQL数据库的SQL语句不区分大小写,关键字建议大写。
4. 注释:
单行注释: -- 注释内容 或 # 注释内容(MySQL特有)
多行注释: /* 注释内容 */
2. SQL分类
DDL Data Definition Language
数据定义语言,用来定义数据库对象(数据库、表、字段)
DML Data Manipulation Language
数据操作语言,用来对数据库表中的数据进行增删改
DQL Data Query Language
数据查询语言,用来查询数据库中表的数据
DCL Data Control Language
数据控制语言,用来创建数据库用户、控制数据库的访问权限
3. 字段类型
3.1 数据类型
3.2 字符串类型
3.3 日期类型
案例:
根据需求创建表(设计合理的数据类型)、
设计一张员工信息表,要求如下:
1. 编号(纯数字)
2. 员工工号(字符串类型,长度不超过10位)
3. 员工姓名(字符串类型,长度不超过10位)
4. 性别(男/女,存储1个汉字)
5. 年龄(正常人年龄,不可能存储负数)
6. 身份证号(二代身份证号均为18位,身份证中有X这样的字符)
7. 入职时间(取值年月日即可)
SQL语句:
1 2 3 4 5 6 7 8 9 | CREATE TABLE emp( id INT COMMENT '编号' , work_id VARCHAR (10) COMMENT '员工工号' , name VARCHAR (10) COMMENT '员工姓名' , gender CHAR (1) COMMENT '性别' , age TINYINT UNSIGNED COMMENT '年龄' , idcard CHAR (18) COMMENT '身份证号' , entrydate DATE COMMENT '入职时间' )COMMENT '员工表' ; |
4. DDL
4.1 DDL-库操作
4.1.1 库查询
1 2 3 4 | -- 查询所有数据库 语法如下: SHOW DATABASES; -- 查询当前数据库 语法如下: SELECT DATABASE (); |
4.1.2 库创建
1 2 | -- 创建数据库 语法如下: CREATE DATABASE [IF NOT EXITS] 数据库名 [ DEFAULT CHARSET 字符集][ COLLATE 排序规则]; |
4.1.3 库删除
1 2 | -- 删除数据库 语法如下: DROP DATABES [IF EXITS] 数据库名; |
4.1.4 库使用
1 2 | -- 使用数据库 语法如下: USE 数据库名; |
4.2 DDL-表操作
4.2.1 表查询
1 2 3 4 5 6 | -- 查询当前数据库所有表 语法如下: SHOW TABLES; -- 查询表结构 语法如下: DESC 表名; -- 查询指定表的创建语句 语法如下: SHOW CREATE TABLE 表名; |
4.2.2 表创建
1 2 3 4 5 6 7 8 | -- 创建表语句,SQL语法如下: CREATE TABLE 表名( 字段1 字段1类型[COMMENT 字段1注释], 字段2 字段2类型[COMMENT 字段2注释], 字段3 字段3类型[COMMENT 字段3注释], ...... 字段n 字段n类型[COMMENT 字段n注释] )[COMMENT 表注释] |
4.2.3 表修改
添加字段
1 2 | -- 添加表字段 语法如下: ALTER TBALE 表名 ADD 字段名 类型(长度)[COMMENT 注释][约束]; |
案例:
为emp表增加一个新的字段"昵称"为nickname,类型为varchar(20)
1 | ALTER TABLE emp ADD nickname VARCHAR (20) COMMENT '昵称' ; |
修改数据类型
1 2 | -- 修改表字段数据类型 语法如下: ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度); |
修改字段名和字段类型
1 2 | -- 修改表字段名和字段类型 语法如下: ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度)[COMMENT 注释][约束]; |
案例:
将emp表的nickname字段修改为username,类型为varchar(30);
1 | ALTER TABLE emp CHANGE nickname username VARCHAR (30) COMMENT '用户名' ; |
4.2.4 表删除
1 2 | -- 删除某个表字段名 语法如下: ALTER TABLE 表名 DROP 字段名; |
案例:
将emp表的字段username删除
1 | ALTER TABLE emp DROP username; |
删除表
1 2 3 4 | -- 删除表 语法如下: DROP TBALE [IF EXITS] 表名; -- 删除指定表,并重新创建该表 语法如下: TRUNCATE TABLE 表名; |
注意:
在删除表时,表里面的数据也会被删除
4.2.5 修改表名
1 2 | -- 修改表名 语法如下: ALTER TABLE 表名 RENAME TO 新表名; |
案例:
将emp表的表名修改为employee
1 | ALTER TABLE emp RENAME TO employee; |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!