目录
一. CRUD(增删改查)
1.1 SELECT(查询)
概念
语法
含义
1.2 INSERT(新增)
概念
语法
含义
1.3 UPDATE(修改)
语法
含义
1.4 DELETE(删除)
语法
含义
二. 函数
2.1 常见函数
字符函数
数字函数
日期函数
2.2 流程控制函数
语法
示例
2.3 聚合函数
三. UNION与UNION ALL
概念
语法
专业词解释
使用场景
实例
全列
单列
结论
思维导图
一. CRUD(增删改查)
1.1 SELECT(查询)
概念
查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。
语法
SELECT{* | }[FROM , …[WHERE [GROUP BY [HAVING [{ }…]][ORDER BY ][LIMIT[,] ]]
含义
- {*|}包含星号通配符的字段列表,表示所要查询字段的名称。
- ,…,表 1 和表 2 表示查询数据的来源,可以是单个或多个。
- WHERE 是可选项,如果选择该项,将限定查询数据必须满足该查询条件。
- GROUP BY,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。
- [ORDER BY],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
- [LIMIT[,]],该子句告诉 MySQL 每次显示查询出来的数据条数。
1.2 INSERT(新增)
概念
使用INSERT语句向数据库已有的表中插入一行或多行数据。
语法
- INSERT…VALUES语句
INSERT INTO [ [ , … ] ]VALUES (值1) [… , (值n) ];
INSERT…SET语句
INSERT INTO SET = , = ,…
含义
- :指定被操作的表名。
:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERTVALUES(…) 即可。
VALUES
或VALUE
子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。
由 INSERT 语句的两种形式可以看出:
- 使用 INSERT…VALUES 语句可以向表中插入一行数据,也可以插入多行数据;
- 使用 INSERT…SET 语句可以指定插入行中每列的值,也可以指定部分列的值;
- INSERT…SELECT 语句向表中插入其他表的数据。
- 采用 INSERT…SET 语句可以向表中插入部分列的值,这种方式更为灵活;
- INSERT…VALUES 语句可以一次插入多条数据。
1.3 UPDATE(修改)
语法
UPDATE SET 字段 1=值 1 [,字段 2=值 2… ] [WHERE 子句 ][ORDER BY 子句] [LIMIT 子句]
含义
- :用于指定要更新的表名称。
- SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。
- WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
- ORDER BY 子句:可选项。用于限定表中的行被修改的次序。
- LIMIT 子句:可选项。用于限定被修改的行数。
1.4 DELETE(删除)
语法
DELETE FROM [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]
含义
- :指定要删除数据的表名。
- ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
- WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
- LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。
二. 函数
2.1 常见函数
字符函数
- 转小写LOWER(‘SQL Course’) ➡sql course
- 转大写UPPER(‘SQL Course’) ➡SQL COURSE
- 拼接CONCAT(‘hello’,’world’) ➡helloworld
- 截取SUBSTR(‘helloworld’,1,5) ➡hello
- 长度 LENGTH(‘helloworld’) ➡10
- 字符出现索引值INSTR(‘helloworld’,’w’) ➡6
- 字符截取后半段TRIM(‘h’ FROM ‘helloworld’) ➡elloworld
- 字符替换REPLACE(‘abcd’,’a’,’m’) ➡mbcd
数字函数
- 四舍五入ROUND(98.1289, 2) ➡98.13
- 截断TRUNC(98.1289, 2) ➡98.12
- 求余MOD(1600,300) ➡100
日期函数
- 获取当前日期now()
- 将日期格式的字符转换成指定格式的日期STR_TO_DATE(‘9-13-1999’, ‘%m-%d-%Y’) ➡1999-09-13
- 将日期转换成字符 DATE_FORMAT(‘2012/9/9’, ‘%Y年%m月%d日’) ➡2012年9月9日
2.2 流程控制函数
语法
CASE expr WHEN conparison_expr1 THEN return_expr1[WHEN comparison_expr2 THEN return_expr2WHEN comparison_exprn THEN return_exprnELSE else_expr]END
示例
查询同时存在01课程和02课程的情况
SELECTt3.*,(CASE WHEN t1.cid = '01' THEN t1.score END)语文,(CASE WHEN t2.cid = '02' THEN t2.score END)数学,FROM(SELECT *FROM t_mysql_score sc WHERE sc.cid = '01')t1,(SELECT *FROM t_mysql_score sc WHERE sc.cid = '02')t2,t_mysql_student t3WHEREt1.sid = t2.sidAND t1.sid = t3.sid
查询会议信息(包含会议信息表数据,主持人姓名、审批人姓名、会议状态)
SELECT a.id, a.title, a.content, a.canyuzhe, a.liexizhe, a.zhuchiren, b.name, a.location,DATE_FORMAT(a.startTime,'%Y-%m-%d %H:%i:%s')as startTime,DATE_FORMAT(a.endTime,'%Y-%m-%d %H:%i:%s')as endTime,a.state,(case a.statewhen 0 then '取消会议'when 1 then '新建'when 2 then '待审核'when 3 then '驳回'when 4 then '待开'when 5 then '进行中'when 6 then '开启投票'else '结束会议' end)as meetingState, a.seatPic, a.remark, a.auditor, c.name as auditorNameFROM t_oa_meeting_info ainner join t_oa_user b on a.zhuchiren = b.idleft join t_oa_user c on a.auditor = c.id where 1=1;
2.3 聚合函数
sum求和、avg平均值、max最大值、min最小值、count计算个数
三. UNION与UNION ALL
概念
UNION:用于合并两个或多个SELECT语句的结果集,并去除重复的行。
UNION ALL:用于合并两个或多个SELECT语句的结果集,包括重复的行。
语法
UNION:将多个SELECT语句放在一起,并使用UNION关键字将他们连接起来。每个SELECT语句的列数、列名和数据类型必须相同。
UNION ALL:将多个SELECT语句放在一起,并使用UNION ALL关键字将他们连接起来。每个SELECT语句的列数、列名和数据类型可以不同。
专业词解释
UNION:UNION操作符执行去除重复行的操作,它通过对所有的结果集进行排序和比较来实现。
UNION ALL:UNION ALL操作符不执行去除重复行的操作,它直接将所有的结果集合并在一起。
使用场景
UNION:当需要合并多个查询结果,并且不希望出现重复行时,可以使用UNION操作符。它适用于数据需要去重的情况。
UNION ALL:当需要合并多个查询结果,包括重复行时,可以使用UNION ALL操作符。它适用于不需要去重的情况,或者在已经确定结果不会有重复行的情况下。
实例
全列
初始数据
SELECT *from t_oa_meeting_info where id>=1 and id=6 and id<=10;
UNION
678只出现了一次
SELECT *from t_oa_meeting_info where id>=1 and id=6 and id<=10;
UNION ALL
678重复出现
SELECT *from t_oa_meeting_info where id>=1 and id=6 and id<=10;
单列
初始数据
SELECT id from t_oa_meeting_info where id>=1 and id=6 and id<=10;
UNION
678只出现了一次SELECT id from t_oa_meeting_info where id>=1 and id=6 and id<=10;
UNION ALL
678重复出现
SELECT id from t_oa_meeting_info where id>=1 and id=6 and id<=10;
结论
所谓去重并不需要所有列相同。