数据表的增删改操作,mysql数据库增删改查
墨初 知识笔记 119阅读
第一章MySQL | 数据库的管理和操作(基本介绍)
第二章MySQL | 数据库的基本操作和表的基本操作

第三章MySQL | 数据库的表的增删改查
文章目录 MySQL | 数据库的管理和操作【表的增删改查】系列文章目录本节目标一、新增Create指定列插入 全列插入多次插入时间日期类型数据的插入 二、查询Retrieve全列查找指定列查询表达式查询指定别名查询去重查询结果排序条件查询范围查询模糊查询NULL 的查询分页查询 三、修改Update四、删除Delete内容重点总结

本节目标
CRUD : Create, RetrieveUpdateDelete
新增数据
查询数据
修改数据
删除数据
注释在SQL中可以使用“–空格描述”来表示注释说明
CRUD
即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写。
语法
INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ...value_list: value, [, value] ...
案例
insert into student valuse (1,张三);
这里的个数类型顺序和表头结构匹配SQL没有字符类型‘’
和“”
都可以表示字符串这里数据库在插入的有的时候是报错这是因为在数据库不做任何修改默认情况下创建数据库的字符集是拉丁文
字符集不能表示中文 此时我们要做的事情就是让我们的数据库字符集和你输入的时候设置生utf-8
create database test charset utf8;
现在就可以了一般来说我们的终端是utf8的但是有的同学是gbk的其中utf8
正常保存数据是没事的带上表情就有可能出错了而utf8mb4
是更完整的utf8 指定列插入 全列插入 插入两条记录value_list 数量必须和指定列数量及顺序一致 insert into student (name,gender) values(张三,男);
此时values
后面的内容就是和前面的的内容匹配
select * from student;
多次插入 这里也可以一次性插入多条数据那就是一次插入 insert into student values(2,李四,男),(3,王五,男);
一次插入n个记录比一次插入一个数据分n次插入效率要高 时间日期类型数据的插入 create table homework (id int ,creatTime datetime);
插入时间的时候是通过特定格式的字符串来表示时间日期的如‘2023-02-17 21:25:00’
insert into homework values(1,2023-02-17 21:25:00);
那么我现在就想把这个时间日期设置成当前时刻咋办sql提供了一个特殊的函数now()
insert into homework values(1,now());
二、查询Retrieve 全列查找 全列查找查找整个表的所有行所有列
select * from 表名
这里面的*
表示所有的列这种特殊含义的符号计算机中叫做【通配符】 但是这里执行select *
操作肯会非常危险如果数据量就几百几千就没有什么事如果数据量有几亿几十亿select *
操作就很麻烦了这个操作会瞬间吃满硬盘带宽和网络带宽就可能导致其他程序无法使用硬盘或者使用网络 那么怎么办呢有办法吗有的
当你需要操作的时候一定要拉上一个人和你一起操作O(∩_∩)O哈哈~
指定列查询-- 指定列的顺序不需要按定义表的顺序来 select 列名,列名...from 表名;
我们需要哪些列就查询哪些列 select name,gender from student;
表达式查询 查询过程中可以做一些简单的运算~~这个是进行列
和列
之间的运算 create table exam_result (id int,name varchar(20),chinese decimal(3,1),math decimal(3,1),english decimal(3,1));
insert into exam_result (id,name,chinese,math,english) values (1,唐三藏, 67, 98, 56), (2,孙悟空, 87.5, 78, 77), (3,猪悟能, 88, 98.5, 90), (4,曹 孟德, 82, 84, 67), (5,刘玄德, 55.5, 85, 45), (6,孙权, 70, 73, 78.5), (7,宋公明, 75, 65, 30);
select name,math 10 from exam_result;
这个结果都是在原有的分数上 10的
上述这样的查询数据库服务器硬盘的数据是否发生了改变
如果我们再次查询math此时的结果是 10之前的还是 10之后的呢
我们再次操作一下~~
小结一下
临时表
的形式展现出来这只是在客户端这里显示一下临时表和服务器那边的硬盘上的表没啥关系 我们还可以查看总成绩那么怎么查看呢接着往下看~~
select name,math chinese english from exam_result;
表达式查询
是让列和列之间进行运算而不是行和行之间
后面还会学一个聚合查询
是行和行之间的运算~~
这就引出了一个查询的时候指定别名~~
指定别名查询 指定别名就相当于是 起了个“小名”更方便的来理解含义我们可以使用as
关键字来查询下面进行演示 select name,math chinese english as total from exam_result;
可以看到我们查询出来的名字发生了变化~~ 其中 as
可以省略但是不建议~~ 去重 我们可以使用distinct
关键字进指定列进行去重把重复的行只保留一个接着看~~ select distinct math from exam_result;
distinct指定多个列的时候要求这些列的值都相同才视为重复 查询结果排序 使用了order by
子句指定某些列进行排序~~排序可能是升序也可能是降序
order by 是可以根据多个列进行排序~~
比如说按照数学成绩进行升序排序
select name,math from exam_result order by math;
对于MySQL来说如果一个sql没有指定order by此时查询的结果的顺序是不可预期的
代码逻辑中不能依赖这里的查询顺序的
刚刚是升序排序的那么怎么降序排序呢只需要在后面加上desc
就可以了
select * from exam_result order by math desc;
此处的desc
是descend
单词的缩写,不是describe
还可以使用asc
表示升序排序但是省略不写默认就是升序
还可以指定多个列来排序多个列之间使用来分割 这个列越靠前就是越关键的排序依据~~
先按照第一列排序如果第一列的值相同了再按照第二列排序
select * from exam_result order by math desc,chinese desc;
条件查询 在查询的时候指定筛选条件
需要先描述条件怎么描述条件呢sql通过一系列的运算符来表示条件~~比较运算符
逻辑运算符
通过where子句再搭配上条件表达式就可以完成条件查询~~select * from exam_result where english < 60;
我们来看一下 其中的where english < 60
相当于针对数据库的表进行遍历取出每一行数据把数据代入条件中看条件是否符合如果是真
这个记录就保留作为结果集的一部分如果是 假这个记录就pass下一条继续~~ 条件查询可以直接拿两个列进行比较~~ select * from exam_result where chinese > english;
这里和上面的where english < 60
一样都是取出每一行数据把数据代入条件中看条件是否符合 条件查询可以使用表达式来作为条件 select * from exam_result where chinese english math < 200;
这样写是不是不明显那我们还可以下面这样写 select name,chinesemathenglish from exam_result where chinese english math < 200;
这样写是不是更加直观~~还记得吗有一个as
的关键词~~那么是不是可以下面这样写 select name,chinese math english as total from exam_result where total < 200;
可以看到是报错了~~在上面的代码中写下一个sql不是从前往后的执行执行顺序是有特定的规则的执行规则 遍历每一行把这一行代入where的条件中符合条件的结果再根据select这里指定的列再进行查询/计算
注意
此处的total别名不能作为where条件和当前sql的执行顺序有关当然这也是mysql对于语法规定的一部分~~
所以只能写成原有的表达式~select name,chinese math english as total from exam_result where chinese math english < 200;
select * from exam_result where chinese > 80 and english > 80;
select * from exam_result where chinese > 80 or english > 80;
如果一个where
中既存在and
有存在or
那么它们的优先级是先执行and
后执行or
范围查询 BETWEEN … AND …
约定的一个前闭后闭区间包含两侧边界select * from exam_result where chinese > 80 and chinese < 90;
或者也可以写成下面的代码这两种写法本质上是一样的~~ select * from exam_result where chinese between 80 and 90;
select * from exam_result where math 58 or math 59 or math 98 or math 99;
或者也可以这样写 select * from exam_result where math in(58,59,98,99);
模糊查询 like
模糊匹配不要求元素完全相同只要满足一定的规则就可以了
like 功能比正则表达式简单的多
只支持两个用法
使用%代表任意0个字符或者N个字符使用_代表任意1个字符 列如查询姓孙的同学select * from exam_result where name like 孙%;
可以看到查询出来了列如用_来模糊查找 还可以下面这样写~~like %孙
查询结尾的like%孙%
查询包含孙的 mysql效率比较低的很容易称为性能瓶颈模糊匹配更是比较低效的写法如果这里支持的功能更复杂反而更拖慢数据库的效率~~使用数据库就算优化出来也达不到要求我们的做法是不用数据库数据都放在内存中搜索~~ NULL 的查询 我们要想查询为空null的值那么怎么查询吗是下面这样吗
select * from exam_result where chinese null;
为什么会出现这样的情况
null和其他数值进行运算结果还是nullnull结果在条件中想当于false
所以null null 结果等于null --> false; 针对这样的问题怎么解决呢
在sql里提供了这样的一个比较相等的<>
,使用这个比较相等运算就可以处理null的比较~可以看到就可以查询成功了 select * from exam_result where chinese <> null
或者也可以下面这样写对空值进行判定~~ select * from exam_result where chinese is null;
分页查询 这里所用到的关键字是limit
select * from exam_result limit 3;
可以看到后面这里加上3就是只显示3条 limit还可以搭配offset声明从那一条开始查询从0开始计数下面进行代码演示~~ select * from exam_result limit 3 offset 3;
还有一种写法limit 3 offset 6
等价于 limit 6,3
这种写法不太推荐很容易混淆~~
limit 这个东西是可以和前面的那些查询搭配使用的~~
列如查询总分前三名的同学的信息
计算每个同学的总成绩表达式按照成绩排序降序取前三条记录代码操作
select name,chinese english math as total from exam_result order by total desc limit 3;
注意这里的order by是可以使用别名的 查询基础部分暂时告一段落~~
三、修改Updateupdate 表名 set 列名 值... where 条件;
我们接着看练习update exam_result set math 80 where name 孙悟空;
我们再进行查看可以看到已经修改成功了~~ update exam_result set math 60 ,chinese 70 where name 曹孟德;
select name, chinese math english as total from exam_result order by total desc;
首先我们查看有哪些同学是倒数三名的~~null在排序的时候视为最小的值~~ 然后我们接下来再进行将总成绩倒数前三的 3 位同学的数学成绩加上 30 分 update exam_result set math math 30 order by chinese math english asc limit 3;
如果要加的的数字超出范围了就会报错原来的成绩不会修改 我们加上10应该就不会报错了~~ update exam_result set math math 10 order by chinese math english asc limit 3;
可以看到已经加成功了~~ 这里如果要改成两倍的话就会超出范围我们就修改成0.5倍~ update exam_result set chinese chinese / 2;
我们这里可以查看警告 show warnings;
其中里面的truncated意思就是截断小数点后位数不够了只能截断了~ 这两个成绩已经是截断后的成绩了~~ 四、删除Delete delete删除记录行
delete from 表名 where 条件;
删除姓孙的考试成绩 下面进行代码演示
delete from exam_result where name like 孙%;
这里就是把条件匹配出来的结果都删掉了 那么有同学说表名后面不加条件会不会里面的内容都会删除会的
delete from exam_result;
可以看到已经全部删除了这个操作基本相当于删表 所以delete操作也是非常危险的
学习完上面的操作那么增删改查都是什么呢
增insert into 表名...
删delete from 表名...
改update 表名...
查select from 表名...
内容重点总结 新增 -- 单行插入insert into 表(字段1, ..., 字段N) values (value1, ..., value N);-- 多行插入insert into 表(字段1, ..., 字段N) values(value1, ...),(value2, ...),(value3, ...);
查询 -- 全列查询select * from 表-- 指定列查询select 字段1,字段2... from 表-- 查询表达式字段select 字段1100,字段2字段3 from 表-- 别名select 字段1 别名1, 字段2 别名2 from 表-- 去重DISTINCTselect distinct 字段 from 表-- 排序ORDER BYselect * from 表 order by 排序字段-- 条件查询WHERE-- (1)比较运算符 (2)BETWEEN ... AND ... (3)IN (4)IS NULL (5)LIKE (6)AND (7)OR (8)NOTselect * from 表 where 条件
修改 update 表 set 字段1value1, 字段2value2... where 条件
删除 delete from 表 where 条件
好了数据库的管理和操作【表的增删改查】初阶就到这里结束了后面我们还有进阶感谢大家的收看觉得有用的话三连吧