MySQL的CRUD操作&&函数介绍&&union和union all

这篇具有很好参考价值的文章主要介绍了MySQL的CRUD操作&&函数介绍&&union和union all。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一. 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 <表 1>, <表 2>…
[WHERE <表达式>
[GROUP BY <group by definition>
[HAVING <expression> [{<operator> <expression>}…]]
[ORDER BY <order by definition>]
[LIMIT[<offset>,] <row count>]
]

含义

  • {*|<字段列名>}  包含星号通配符的字段列表,表示所要查询字段的名称。
  • <表 1>,<表 2>…,表 1 和表 2 表示查询数据的来源,可以是单个或多个。
  • WHERE <表达式>  是可选项,如果选择该项,将限定查询数据必须满足该查询条件。
  • GROUP BY< 字段 >,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。
  • [ORDER BY< 字段 >],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
  • [LIMIT[<offset>,]<row count>],该子句告诉 MySQL 每次显示查询出来的数据条数。

 1.2 INSERT(新增)

概念

使用INSERT语句向数据库已有的表中插入一行或多行数据。

语法

  • INSERT…VALUES语句
INSERT INTO <表名> [ <列名1> [ , … <列名n>] ]
VALUES (值1) [… , (值n) ];
  • INSERT…SET语句

INSERT INTO <表名>
SET <列名1> = <值1>,
    <列名2> = <值2>,
    …

含义

  • <表名>:指定被操作的表名。
  • <列名>指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。
  • VALUES 或 VALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

由 INSERT 语句的两种形式可以看出:

  1. 使用 INSERT…VALUES 语句可以向表中插入一行数据,也可以插入多行数据;
  2. 使用 INSERT…SET 语句可以指定插入行中每列的值,也可以指定部分列的值;
  3. INSERT…SELECT 语句向表中插入其他表的数据。
  4. 采用 INSERT…SET 语句可以向表中插入部分列的值,这种方式更为灵活;
  5. 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_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END

 示例

查询同时存在01课程和02课程的情况

SELECT 
t3.*,
(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 t3
WHERE
t1.sid = t2.sid
AND 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.state
when 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 auditorName
FROM t_oa_meeting_info a
inner join t_oa_user b on a.zhuchiren = b.id
left 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<=8;
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

UNION

678只出现了一次

SELECT *from t_oa_meeting_info where id>=1 and id<=8
UNION
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

UNION ALL 

678重复出现

SELECT *from t_oa_meeting_info where id>=1 and id<=8
UNION ALL
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

单列

初始数据

SELECT id from t_oa_meeting_info where id>=1 and id<=8;
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

UNION
678只出现了一次

SELECT id from t_oa_meeting_info where id>=1 and id<=8
UNION
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

UNION ALL 

678重复出现

SELECT id from t_oa_meeting_info where id>=1 and id<=8
UNION ALL
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

结论

所谓去重并不需要所有列相同。

思维导图

MySQL的CRUD操作&&函数介绍&&union和union all,mysql,数据库文章来源地址https://www.toymoban.com/news/detail-819478.html

到了这里,关于MySQL的CRUD操作&&函数介绍&&union和union all的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SQL中的UNION和UNION ALL的区别及用法详解、“提高SQL查询效率:UNION和UNION ALL的比较、使用实例详解SQL中的UNION和UNION ALL操作符

    UNION 和 UNION ALL 都是 SQL 中用于将多个 SELECT 语句的结果合并成一个结果集的操作符。它们都适用于需要将多个表或查询结果合并在一起的情况。但是它们的行为略有不同。 UNION 和 UNION ALL 的区别在于, UNION 会将结果集合并成一个不含重复行的结果集,而 UNION ALL 则会保留所有

    2024年02月03日
    浏览(47)
  • mysql奇葩问题union

    单独执行第一条,有三条结果; union之后,只有一条结果; union自动的把重复数据合并了;

    2024年04月29日
    浏览(19)
  • [SQL] union all

    UNION ALL 是一个用于合并多个查询结果集的操作符。它将多个 SELECT 查询的结果合并成一个结果集,并且保留所有的行,包括重复的行。 具体语法如下: 在上述语法中,UNION ALL 用于合并来自 table1 和 table2 的查询结果集。 这两个查询 必须拥有相同的列数和相似类型的列 。 U

    2024年02月07日
    浏览(30)
  • 【mysql】—— 函数的基本介绍

    前言: MySQL是一种常用的关系型数据库管理系统,它提供了许多内置的函数来进行数据操作和处理。本期,我将给大家介绍的就是关于 “ 函数 ” 的相关知识!!! 目录 (一)日期函数 (二)字符串函数 (三)数学函数 (四)其它函数 总结 MySQL提供了一系列用于处理日期

    2024年02月07日
    浏览(30)
  • ORACLE中UNION、UNION ALL、MINUS、INTERSECT学习

    1、UNION和UNION ALL的使用与区别 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all。union的作用是将多个结果合并在一起显示出来。 union和union all的区别是union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部

    2024年02月12日
    浏览(32)
  • GaussDB数据库SQL系列-UNION & UNION ALL

    目录 一、前言 二、GaussDB  UNION/UNION ALL 1、GaussDB UNION 操作符 2、语法定义 三、GaussDB实验示例 1、创建实验表 2、合并且除重(UNION) 3、合并不除重(UNION ALL) 4、合并带有WHERE子句SQL结果集(UNION ALL) 5、业务逻辑除重后合并(UNION ALL) 四、GaussDB UNION常见错误 1、“each UNION que

    2024年02月12日
    浏览(28)
  • union all简写xml

    2024年02月13日
    浏览(27)
  • 【MySQL】MySQL 数据库的介绍与操作

    目录 1. 登录 MySQL 数据库 2. MySQL 介绍 3. 操作数据库 1、创建数据库 2、删除数据库 3、插入数据 4、查找 5、修改数据库 4. 表的操作 1、创建表 2、查看表 3、修改表 4、删除表 写在最后: 指令: 这里我来介绍一下他的选项,-h 表示指明登录部署 MySQL 服务的主机,-P 表示我们要

    2024年02月14日
    浏览(34)
  • 【MySQL】MySQL表的增删改查(CRUD)

    ✨个人主页:bit me👇 ✨当前专栏:MySQL数据库👇 ✨算法专栏:算法基础👇 ✨每日一语:生命久如暗室,不碍朝歌暮诗   CRUD : Create,Retrieve,Update,Delete 新增数据 查询数据 修改数据 删除数据 MySQL的工作就是组织管理数据,先保存,保存好了后好进行增删改查 增删改查的

    2024年02月02日
    浏览(34)
  • Mysql对日期的操作函数

    当涉及到日期操作时,MySQL提供了许多内置的日期函数。以下是一些常用的MySQL日期函数以及带有返回值的示例: CURDATE():返回当前日期。 示例:SELECT CURDATE(); -- 返回当前日期,例如:2024-01-09 NOW():返回当前日期和时间。 示例:SELECT NOW(); -- 返回当前日期和时间,例如:20

    2024年02月01日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包