MySQL数据库 -- 表的增删查改

                       MySQL数据库 -- 表的增删查改_第1张图片

       今天来讲MySQL数据库的表增删查改操作。今天主要是通过栗子来演示语法使用的,话不多说,直奔主题~

表的增删查改:

CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除)

目录

Create

单行数据 + 全列插入 

多行数据 + 指定列插入 

 插入否则更新

替换

​编辑Retrieve

select列 

全列查询

指定列查询

 查询字段为表达式

 结果去重

where条件

>, >=, <, <= 

=, <=>

BETWEEN a0 AND a1

 IN (option, ...)

LIKE 

语文成绩好于英语成绩的同学 

总分在 200 分以下的同学 

 语文成绩 > 80 并且不姓孙的同学

 孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80 

NULL的查询 

结果排序 

同学及 qq 号,按 qq 号排序显示

查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示 

查询同学及总分,由高到低 

查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示 

筛选分页结果 

limit n

limit s,n 

 limit n offset s

Update

将孙悟空同学的数学成绩变更为 80 分

将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分 

将总成绩倒数前三的 3 位同学的数学成绩加上 30 分 

将所有同学的语文成绩更新为原来的 2 倍 

Delete 

删除数据

删除孙悟空同学的考试成绩

删除整张表数据 

截断表

delete from 和 truncate [table] 

插入查询结果

案例:删除表中的的重复复记录,重复的数据只能有一份

聚合函数

 统计班级共有多少同学

统计班级收集的 qq 号有多少 

 统计本次考试的数学成绩分数个数

统计数学成绩总分 

统计平均总分 

 返回英语最高分 

统计平均总分 

返回 > 70 分以上的数学最低分 

group by子句的使用 

测试数据导入

如何显示每个部门的平均工资和最高工资 

显示每个部门的每种岗位的平均工资和最低工资 

显示平均工资低于2000的部门和它的平均工资 

where 和having比较


Create

语法

insert [into] table_name[(column [, column] ...)] values (value_list) [, (value_list)] ...

创建案例:

单行数据 + 全列插入 

举个栗子:

MySQL数据库 -- 表的增删查改_第2张图片

多行数据 + 指定列插入 

举个栗子:

MySQL数据库 -- 表的增删查改_第3张图片

 插入否则更新

由于 主键 或者 唯一键 对应的值已经存在而导致插入失败

选择同步性更新语法:

insert ... on duplicate key update column = value [, column = value] ...

举个栗子:

MySQL数据库 -- 表的增删查改_第4张图片

        我们插入数据时有主键或者唯一键冲突了,我们使用on duplicate key update后,哪一个键先冲突,就更新那一行的数据内容,按照update后的内容进行更新。 

替换

-- 主键 或者 唯一键 没有冲突,则直接插入;
-- 主键 或者 唯一键 如果冲突,则删除后再插入

REPLACE INTO students (sn, name) VALUES (20001, '曹阿瞒');
Query OK, 2 rows affected (0.00 sec)
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,删除后重新插入

举个栗子:

MySQL数据库 -- 表的增删查改_第5张图片

多个列数据冲突时:

MySQL数据库 -- 表的增删查改_第6张图片Retrieve

准备工作,创建表结构:

MySQL数据库 -- 表的增删查改_第7张图片

select列 

全列查询

-- 通常情况下不建议使用 * 进行全列查询
-- 1. 查询的列越多,意味着需要传输的数据量越大,会导致数据大量刷屏,效率降低;
-- 2. 可能会影响到索引的使用。

指定列查询

MySQL数据库 -- 表的增删查改_第8张图片

 查询字段为表达式

MySQL数据库 -- 表的增删查改_第9张图片

 结果去重

举个栗子:

MySQL数据库 -- 表的增删查改_第10张图片

注意distinct后面跟一个列名和多个列名的情况。 

where条件

关于比较运算符如下,我们下面通过场景来学习。

MySQL数据库 -- 表的增删查改_第11张图片

>, >=, <, <= 

MySQL数据库 -- 表的增删查改_第12张图片

 MySQL数据库 -- 表的增删查改_第13张图片

注意,MySQL中比较等于时,是用=来比较的,和语言中的等号是不同的。 

=, <=>

MySQL数据库 -- 表的增删查改_第14张图片

那判断不为NULL呢?

MySQL数据库 -- 表的增删查改_第15张图片

        在这里判断是否为NULL虽说不止一种写法,但是我们只要使用is noll 和is not null来判断就好了,这样降低自己的学习成本,还看起来比较主观。 

BETWEEN a0 AND a1

逻辑运算符:

MySQL数据库 -- 表的增删查改_第16张图片

MySQL数据库 -- 表的增删查改_第17张图片

 IN (option, ...)

MySQL数据库 -- 表的增删查改_第18张图片

LIKE 

MySQL数据库 -- 表的增删查改_第19张图片

语文成绩好于英语成绩的同学 

MySQL数据库 -- 表的增删查改_第20张图片

总分在 200 分以下的同学 

MySQL数据库 -- 表的增删查改_第21张图片

 我们要注意where和order by语句的执行顺序。

where语句中不能取别名

MySQL数据库 -- 表的增删查改_第22张图片

 语文成绩 > 80 并且不姓孙的同学

MySQL数据库 -- 表的增删查改_第23张图片

 孙某同学,否则要求总成绩 > 200 并且 语文成绩 < 数学成绩 并且 英语成绩 > 80 

MySQL数据库 -- 表的增删查改_第24张图片

NULL的查询 

MySQL数据库 -- 表的增删查改_第25张图片

结果排序 

MySQL数据库 -- 表的增删查改_第26张图片

MySQL数据库 -- 表的增删查改_第27张图片

同学及 qq 号,按 qq 号排序显示

MySQL数据库 -- 表的增删查改_第28张图片

查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示 

MySQL数据库 -- 表的增删查改_第29张图片

查询同学及总分,由高到低 

MySQL数据库 -- 表的增删查改_第30张图片

查询姓孙的同学或者姓曹的同学数学成绩,结果按数学成绩由高到低显示 

MySQL数据库 -- 表的增删查改_第31张图片

筛选分页结果 

-- 起始下标为 0
-- 从 0 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;


-- 从 s 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;


-- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

limit n

MySQL数据库 -- 表的增删查改_第32张图片

limit s,n 

      MySQL数据库 -- 表的增删查改_第33张图片

 limit n offset s

MySQL数据库 -- 表的增删查改_第34张图片

Update

UPDATE table_name SET column = expr [, column = expr ...] [WHERE ...] [ORDER BY ...] [LIMIT ...]

将孙悟空同学的数学成绩变更为 80 分

MySQL数据库 -- 表的增删查改_第35张图片

将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分 

MySQL数据库 -- 表的增删查改_第36张图片

将总成绩倒数前三的 3 位同学的数学成绩加上 30 分 

MySQL数据库 -- 表的增删查改_第37张图片

将所有同学的语文成绩更新为原来的 2 倍 

MySQL数据库 -- 表的增删查改_第38张图片

注意一个细节:

MySQL数据库 -- 表的增删查改_第39张图片

Delete 

删除数据

DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]

删除孙悟空同学的考试成绩

MySQL数据库 -- 表的增删查改_第40张图片

删除整张表数据 

MySQL数据库 -- 表的增删查改_第41张图片

        我们使用delete from 表名删除表数据后,对于表结构是不改变的。 如auto_increment字段记录的默认值是不变的。

截断表

truncate [TABLE] table_name

MySQL数据库 -- 表的增删查改_第42张图片

举个栗子:

MySQL数据库 -- 表的增删查改_第43张图片

delete from 和 truncate [table] 

MySQL数据库 -- 表的增删查改_第44张图片

        delete from操作会被记录在bin log日志中,而truncate操作是不会记录在bin log记录中,说明后者是不适合数据备份的。 

插入查询结果

案例:删除表中的的重复复记录,重复的数据只能有一份

MySQL数据库 -- 表的增删查改_第45张图片

去重操作:

MySQL数据库 -- 表的增删查改_第46张图片

聚合函数

MySQL数据库 -- 表的增删查改_第47张图片

 统计班级共有多少同学

MySQL数据库 -- 表的增删查改_第48张图片

统计班级收集的 qq 号有多少 

          MySQL数据库 -- 表的增删查改_第49张图片

 统计本次考试的数学成绩分数个数

MySQL数据库 -- 表的增删查改_第50张图片

统计数学成绩总分 

MySQL数据库 -- 表的增删查改_第51张图片

统计平均总分 

MySQL数据库 -- 表的增删查改_第52张图片

 返回英语最高分 

MySQL数据库 -- 表的增删查改_第53张图片

统计平均总分 

MySQL数据库 -- 表的增删查改_第54张图片

返回 > 70 分以上的数学最低分 

MySQL数据库 -- 表的增删查改_第55张图片

group by子句的使用 

测试数据导入

MySQL数据库 -- 表的增删查改_第56张图片

如何显示每个部门的平均工资和最高工资 

MySQL数据库 -- 表的增删查改_第57张图片

显示每个部门的每种岗位的平均工资和最低工资 

MySQL数据库 -- 表的增删查改_第58张图片

显示平均工资低于2000的部门和它的平均工资 

MySQL数据库 -- 表的增删查改_第59张图片

        注意,对于这种情况分组是排到第一步的,where使用就不合适了,因为where几乎是先执行的子句,这时候我们只能借助having来帮助我们筛选。 

where 和having比较

MySQL数据库 -- 表的增删查改_第60张图片

 where和having可以一起配合使用

MySQL数据库 -- 表的增删查改_第61张图片

 给博主点个赞呗~

                            MySQL数据库 -- 表的增删查改_第62张图片

你可能感兴趣的:(MySQL数据库,数据库,mysql)