MySQL增删改查操作 -- CRUD

news2025/4/21 15:45:59

个人主页:顾漂亮

目录

1.CRUD简介

2.Create新增

使用示例:

注意点:

3.Retrieve检索

使用示例:

注意点:

4.where条件查询

前置知识:-- 运算符

比较运算符

使用示例: 

注意点:

5.Order by 排序

使用示例:

注意点:

6.分页查询

使用示例:

注意点:

7.Update修改

使用示例:

注意点:

8.Delete删除

使用示例:

注意点:

9.截断表

使用示例:

注意点:

10.插入查询结果

使用示例:

注意点:

11.聚合函数

常见聚合函数:

12.group by分组查询

使用示例:

注意点:


 

1.CRUD简介

  • Create(创建)

  • Retrieve(读取)

  • Update(更新)

  • Delete(删除)

2.Create新增

使用示例:

use ghr;
-- create新增
drop table if exists users; -- 在创建之前添加一层校验
create table users(
  id bigint primary key auto_increment, -- 为id列设置自增主键
  name varchar(20) not null  -- 为name列设置不为空条件
);

-- 显示表   -- 使用该语句前必须先使用use 语句,进入一个数据库中!!!!
show tables;

-- 单行数据全插入  values 中的数据顺序必须要与列的顺序一致
insert into users values (1, '张三');  -- 注意:MySQL中的字符串需要用单引号包裹

-- 单行数据指定列插入  -- values中的数据 必须要与users后面括号中的顺序一致
insert into users(id, name) values (3, '王五'); 

-- 多行数据指定列插入  多个数据中间用 , 分开即可 
insert into users(id, name) values (4, '赵六'), (5, '钱七');

select * from users; 

注意点:

  1. 一次插入一条数据的效率高还是一次插入多条数据的效率更高?

  • 执行所有的SQL语句都会有网络开销

  • MySQL数据库在保存数据的时候也会有磁盘开销

  • 每执行一条SQL语句都需要开启一个事务,事务的开启到关闭也需要消耗资源

  • 因此:一次提交多条数据在一个可控范围内的时候,比一次提交一次数据的效率可以高一点!!

3.Retrieve检索

使用示例:

-- 检索查询
use ghr; -- 使用ghr数据库

-- 首先创建表
drop table if exists exam; -- 添加校验
create table exam(
  id bigint primary key auto_increment,
  name varchar(20) not null, 
  chinese float,
  math float,
  english float 
);

-- 插入测试数据

insert into exam(id, name, chinese, math, english) values 
(1, '唐三藏', 67, 98, 56),(2, '孙悟空', 87, 78, 77),(3, '猪悟能', 88, 98, 90),(4, '曹孟德', 82, 84, 67),(5, '刘玄德', 55, 85, 45),(6, '孙权', 70, 73, 78),(7, '宋公明', 75, 65, 30);

-- 全列查询

select * from exam;


-- 指定列查询

select name, chinese from exam;
select chinese, name from exam; -- 要查询的列只要在表中存在,与顺序无关

-- 查询字段为表达式
# 把所有语文成绩+10
select id, name, chinese+10 as sum from exam;  -- 可以为表达式起一个别名 可以加 as 不加也可以
# 计算总成绩
select id, name, chinese + math + english as 总分 from exam;

-- 为结果去重查询
select distinct math from exam;

注意点:

  • select返回的查询结果是根据查询列表中字段和表达式生成的一个临时表,并不会真正修改数据表中的值

  • select后面的查询列表中指定希望查询的列,可以是一个也可以是多个,中间用逗号隔开。指定列的顺序与表的结构无关

  • 使用disctinct去重时候,只有查询列表中所有列的值相同的时候才会判定为重复

  • 查询不加限制条件会返回表中的所有结果,如果表中的数据量过大,会把服务器的资源消耗殆尽

  • 在生产环境下,一定注意谨慎使用不加限制条件的查询

4.where条件查询

前置知识:-- 运算符

比较运算符

运算符

说明

>,>=,<, <=

与Java/c等用法相同

=

等于,对于NULL的比较不安全,比如NULL = NULL的结果还是NULL

<=>

等于,对于NULL的比较是安全的, 比如NULL <=> NULL 结果为1

!=, <>

不等于

Between A and B

匹配范围[A,B]

Value in(A, B, ....)

如果value在in中返回1,不再返回0

Is null

判断是NULL

Is not null

判断不是NULL

like

模糊匹配

运算符

说明

or

任意一个条件

and

多个条件必须同时成立

not

类似于!取反操作

使用示例: 

-- where条件查询

use ghr;

-- 基本查询
# 英语成绩小于60
select name, english from exam where english <= 60;
# 总成绩200分以下 -- 注意where语句中不可以使用别名
select name, chinese+math+english as 总分 from exam where chinese + math+english < 200;


-- and和or    优先级 -- not > and > as 如果三者混合使用,建议加()
select * from exam where chinese > 80 and english > 80;

select * from exam where chinese > 80 or english > 80;

-- 范围查询

select name, chinese from exam where chinese between 80 and 90;

select name, math from exam where math in(78, 79, 98, 99);

-- 模糊查询

select * from exam where name like '孙%';
# 注意二者区别
select * from exam where name like '孙_';

-- NULL的查询
# 构造数据
insert into exam values (8, '张飞', 27, 0, NULL);

select * from exam where english is null;

select * from exam where english is not null;

# NULL 值与其他值运算结果为NULL
select name, chinese + math + english as sum from exam;

注意点:

  • where条件中可以使用表达式,但是不能使用别名

  • and优先级高于or,在同时使用的时候,建议使用小括号包裹优先执行的部分

  • NULL与任何值运算结果都为NULL

  • 过滤NULL时不要使用 =,!=,<>

5.Order by 排序

使用示例:

-- 前置知识:asc 为升序   desc为降序

-- 按照英语成绩降序
select name, english from exam order by english desc;

-- 查询总分,从高到低
select name, chinese + math + english as 总分 from exam order by 总分 desc; # 可以使用别名进行查询

-- 去除有NULL值的排序
-- 所有英语成绩不为NULL的同学,按照语文成绩从高到低
select name, chinese, math, english from exam where english is not null order by chinese desc;

注意点:

  • 查询中若没有oder by 子句,返回的顺序是未定义的,永远不要依赖这个顺序

  • Order by子句中可以使用列的别名进行排序,注意与where进行区分

  • NULL进行排序的时候,视为比任何值都小,升序出现在最上面,降序出现在最下面

6.分页查询

使用示例:

-- 分页查询   -- 三种方案,以下三种方案查询结果都是相同的

select * from exam order by id asc limit 3; -- 默认从偏移量0位置开始,查询3行数据

select * from exam order by id asc limit 0,3; -- 从偏移量0位置开始查询,查询3条数据

select * from exam order by id asc limit 3 offset 0;-- 从偏移量0位置开始查询,查询3条数据

注意点:

  • 分页查询可以有效控制一次返回的记录条数

  • 可以有效减少数据库服务器的压力,同时对于用户也比较友好

  • 在工作中,一定注意多使用分页查询

7.Update修改

使用示例:

-- 将孙悟空同学数学成绩变为80

update exam set math=80 where name='孙悟空';

-- 将总成绩倒数前3的数学成绩加上5分

# 先查看原始数据
select name, chinese+math+english as sum from exam where chinese+math+english is not null order by sum asc limit 3;

# 注意 where语句中不可以随意起别名
-- 错误示范select name, chinese+math+english from exam where chinese+math+english as sum is not null order by sum asc limit 3;
update exam set math=math+5 where chinese + math + english is not null order by chinese + math + english  asc limit 3;

# 查看查询结果
select name, chinese+math+english as sum from exam where name in ('宋公明', '刘玄德', '唐三藏') order by sum asc;

注意点:

  • 在原值的基础上做变更时,不能使用math+=30这样的语法

  • 不加where条件时,会导致全表数据被更新,谨慎操作

  • 一般情况下类似于这样的更新update exam set math=80 where name='孙悟空';最为合适,先用where语句过滤,再进行更新

8.Delete删除

使用示例:

-- 删除表中一项数据
# 删除表中孙悟空的成绩
delete from exam where name = '孙悟空';

-- 删除整张表的数据
# 准备一个测试表作为备份
create table if not exists t_delete(
  id int,
  name varchar(20)
);
# 插入被测数据
insert into t_delete(id,name) values (1, 'A'), (2, 'B'), (3, 'C');

#删除表格中的数据
delete from t_delete;

注意点:

  • 如果执行delete操作不加限制条件,会将整个表中的数据全部删除,谨慎使用

  • MySQL服务如果开启了二进制日志,每一次的insert、update、delete操作都会记录在二进制日志里,如果需要恢复数据,可以读取日志中的记录,再进行反操作即可、

  • 注意delete只是删除表中的数据,并不会删除表,删除表需要用到表的操作中的drop,注意不要搞混淆

9.截断表

使用示例:

-- 创建测试表
# 检查判断
drop table if exists t_truncate;
create table t_truncate(
  id bigint primary key auto_increment,
  name varchar(20)
);

# 插入测试数据
insert into t_truncate(name) values ('A'), ('B'), ('C');

-- 显示建表结构 -- 以下是在命令行窗口中进行 AUTO_INCREMENT=4
mysql> show create table t_truncate;
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table      | Create Table                                                                                                                                                                                                   |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_truncate | CREATE TABLE `t_truncate` (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

-- 截断表 
mysql> truncate table t_truncate;
Query OK, 0 rows affected (0.03 sec)
-- 显示截断后表的结构 发现AUTO_INCREMENT 被重置为0
mysql> show create table t_truncate;
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table      | Create Table
                                                                                     |
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_truncate | CREATE TABLE `t_truncate` (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+

-- 继续写入数据 AUTO_INCREMENT为1
insert into t_truncate(name) values('d');

注意点:

  • 只能对整表操作,不能像delete一样对部分数据删除

  • 执行truncate操作时会把表的状态重置为初始状态,表中的数据也会被清除

  • 执行truncate不对数据操作所以比delete更快,truncate在删除数据的时候,不经过真正的事务,所以无法回滚

  • 会重置auto_increment

10.插入查询结果

使用示例:


-- 删除表中的重复数据
#首先创建测试表
drop table if exists t_record;
create table t_record(
  id int,
  name varchar(20)
);

#插入测试数据
insert into t_record(id,name) values
(100, 'aaa'),
(100, 'aaa'),
(200, 'bbb'),
(200, 'bbb'),
(200, 'bbb'),
(300, 'ccc');


# 创建一张新表,表结构与t_record相同
drop table if exists t_record_new;
create table t_record_new like t_record;

# 原来表中的数据去重之后copy进入新表
insert into t_record_new select distinct * from t_record;   -- 核心步骤

#新表与原来表重命名
rename table t_record to t_record_old, t_record_new to t_record; 

注意点:

  • 对于重命名表和数据表的迁移一般是由数据库管理员DBA来操作

  • 原始表中的数据一般都不会主动删除,但是真正查询时不需要重复的数据,如果每次查询都使用distinct进行去重操作,会严重影响效率。可以创建一张与t_record表结构相同的表,把去重的记录写入新表中,以后查询都从新表中查,这样真实数据不会丢失,同时也能保证查询效率

11.聚合函数

常见聚合函数:

-- count统计exam表中某一列数据的量
select count(*) from exam;
select count(math) from exam;

-- 语文成绩小于50 的学生人数
select count(chinese) from exam where chinese < 50;

-- sum统计某一列数据的总和
select sum(math) from exam;

# 无法统计非数值列的和
select sum(name) from exam;

-- avg统计某一列的平均数
select avg(math) from exam;

# 统计总分平均分
select round(avg(chinese + math + english),2) as 总分 from exam ;

-- 类比max、min用法与上述例子类似,此处不再一一赘述

12.group by分组查询

使用示例:

-- 准备测试表
drop table if exists emp;
create table emp(
  id bigint primary key auto_increment,
  name varchar(20) not null,
  role varchar(20) not null,
  salary decimal(10,2) not null
);

# 插入测试用例
insert into emp values (1, '马云', '老板', 1500000.00);
insert into emp values (2, '马化腾', '老板', 1800000.00);
insert into emp values (3, '鑫哥', '讲师', 10000.00);
insert into emp values (4, '博哥', '讲师', 12000.00);
insert into emp values (5, '平姐', '学管', 9000.00);
insert into emp values (6, '莹姐', '学管', 8000.00);
insert into emp values (7, '孙悟空', '游戏角色', 956.8);
insert into emp values (8, '猪悟能', '游戏角色', 700.5);
insert into emp values (9, '沙和尚', '游戏角色', 333.3);

-- 统计每个角色的人数
select role, count(*) as sum from emp group by role;

-- 统计每一个角色的最高、最低工资、平均工资
select role, avg(salary), min(salary), max(salary) from emp group by role;

-- 显示平均工资低于1500的角色和它的平均工资  -- having 语句支持别名
select role, avg(salary) as avg from emp group by role having avg < 1500; 
--  having 与 group by的顺序不可以颠倒

注意点:

  • 使用group by进行分组处理之后,对分组的结果进行过滤的时候,不能使用where子句,而要使用having子句

  • Having 用于对分组结果的条件过滤

  • where用于对表中真实数据的条件过滤

  • 在group by执行之前,where已经执行过了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2314740.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【算法day9】回文数-给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。

回文数 给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 回文数是指正序&#xff08;从左向右&#xff09;和倒序&#xff08;从右向左&#xff09;读都是一样的整数。 例如&#xff0c;121 是回文&#…

蛋白质功能预测论文阅读记录2025(DPFunc、ProtCLIP)

前言 最近研究到瓶颈了&#xff0c;怎么优化都提升不了&#xff0c;遂开始看点最新的论文。 DPFunc 2025.1.2 Nature Communication 中南大学 论文地址&#xff1a;DPFunc: accurately predicting protein function via deep learning with domain-guided structure inform…

主流向量数据库对比

在 AI 的 RAG&#xff08;检索增强生成&#xff09;研发领域&#xff0c;向量数据库是存储和查询向量嵌入的核心工具&#xff0c;用于支持高效的语义搜索和信息检索。向量嵌入是文本或其他非结构化数据的数值表示&#xff0c;RAG 系统通过这些嵌入从知识库中检索相关信息&#…

54.HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT 登录模块开发教程&#xff08;八&#xff09;&#xff1a;测试与调试技巧 文章目录 HarmonyOS NEXT 登录模块开发教程&#xff08;…

在Simulink中将Excel数据导入可变负载模块的方法介绍

文章目录 数据准备与格式要求Excel数据格式MATLAB预处理数据导入方法使用From Spreadsheet模块(直接导入Excel)通过MATLAB工作区中转(From Workspace模块)使用1-D Lookup Table模块(非线性负载映射)Signal Builder模块(变载工况导入)可变负载模块配置注意事项与调试在S…

动手学强化学习-记录

3.5 蒙特卡洛方法 统计每一个状态s出现的总次数和总回报&#xff0c;用大数定律&#xff0c;总回报/总次数≈状态s的期望回报 第4章 动态规划算法 策略迭代中的策略评估使用贝尔曼期望方程来得到一个策略的状态价值函数,这是一个动 态规划的过程;而价值迭代直接使用贝尔曼最…

阿里云操作系统控制台评测:国产AI+运维 一站式运维管理平台

阿里云操作系统控制台评测&#xff1a;国产AI运维 一站式运维管理平台 引言 随着云计算技术的飞速发展&#xff0c;企业在云端的运维管理面临更高的要求。阿里云操作系统控制台作为一款集运维管理、智能助手和系统诊断等多功能于一体的工具&#xff0c;正逐步成为企业高效管理…

C++中的const与类型转换艺术

目录 强制转换 static_cast const_cast reinterpret_cast dynamic_cast const关键字 修饰内置类型* 修饰指针类型* 类比 数组指针 指针数组 函数指针 指针函数 强制转换 C语言中的强制转换在C代码中依然可以使用&#xff0c;这种C风格的转换格式非常简单 TYPE a …

特辣的海藻!10

基础知识点 1.清除换行符 scan.nextInt()要加scan.nextLine()清楚换行符。 2.Map.Entry<K, V> Map.Entry是Map接口的嵌套接口&#xff0c;表示一个键值对&#xff08;Key-Value&#xff09; 常用方法&#xff1a; entry.getKey()&#xff1a;获取键 …

sqli-lab靶场学习(八)——Less26-28

前言 25关已经出现了初步的一些关键字过滤&#xff0c;通过双写可以绕过。后面的关卡&#xff0c;我们会遇到更多关键字过滤&#xff0c;需要各种技巧绕过。 Less26 第26关写了会过滤空格和注释符。有很多的答案&#xff0c;会用%a0替代空格&#xff0c;但据说这是sqli-labs部…

双指针算法专题之——复写零

文章目录 题目介绍思路分析异地复写优化为就地复写 AC代码 题目介绍 链接: 1089. 复写零 思路分析 那么这道题我们依然可以使用双指针算法来解决 异地复写 先不考虑题目的要求&#xff0c;直接就地在原数组上修改&#xff0c;可能不太好想&#xff0c;我们这里可以先在一个…

python-leetcode-子数组最大平均数 I

643. 子数组最大平均数 I - 力扣&#xff08;LeetCode&#xff09; 可以使用滑动窗口&#xff08;Sliding Window&#xff09;的方法来解决这个问题。具体步骤如下&#xff1a; 先计算数组 nums 中前 k 个元素的和 sum_k&#xff0c;作为初始窗口的和。然后滑动窗口&#xff0…

【度的数量——数位DP】

题目 分析 数位DP可以解决“区间内满足某种性质的数的个数”的问题 通常按照数位分支&#xff0c;形成一颗数位树 最左分支的值由上界值决定&#xff0c;右分支可以直接计算权重 有可能最左分支会有一个权重 代码 #include <bits/stdc.h> using namespace std;cons…

搭建阿里云专有网络VPC

目录 一、概述 二、专有网络vpc 2.1 vpc基本信息 2.2 vpc资源管理 2.3 vpc网段管理 三、交换机 四、NAT网关 4.1 绑定弹性公网IP 4.2 NAT网关信息 4.3 绑定的弹性公网IP 4.4 DNAT 4.5 SNAT 五、弹性公网IP 六、访问控制ACL&#xff08;绑定交换机&#xff09; 6…

windows系统,pycharm运行.sh文件

博主亲身试验过&#xff0c;流程简单&#xff0c;可用。 需要pycharm &#xff0c;git。 注意需要Git Bash.exe &#xff0c;也就是Git Bash的应用程序&#xff0c;而不是快捷方式。 需要把这个应用程序的路径复制一下。可以通过右键&#xff0c;复制文件地址的方式。 接着在…

论文调研 | 一些开源的AI代码生成模型调研及总结【更新于250313】

本文主要介绍主流代码生成模型&#xff0c;总结了基于代码生成的大语言模型&#xff0c;按照时间顺序排列。 在了解代码大语言模型之前&#xff0c;需要了解代码相关子任务 代码生成 文本生成代码(Text to code):根据自然语言描述生成代码 重构代码&#xff08;Refactoring …

Unity Timeline 扩展

这里认为大家已经会timeline的基本使用了&#xff0c;只介绍怎么自定义扩展。 第一步.自定义Track 首先要自定义一条轨道。剪辑是要在轨道里跑的&#xff0c;系统自带的轨道我们加不了自定义剪辑&#xff0c;得新建自己用的。这个很简单。 [TrackClipType(typeof(TransformTw…

qt介绍信号槽一

信号和槽时qt框架中事件处理的一种机制&#xff0c;qt是基于窗口框架的程序&#xff0c;基于窗口框架额程序都是基于事件的&#xff0c;本质信号对应的就是一个事件&#xff0c;槽对应事件处理的动作。信号槽机制类似于设计模式力的观察者模式。观察者模式就是我一直观察是否有…

【linux】解决 Linux 系统中 root 用户无法打开图形界面问题

【linux】解决 Linux 系统中 root 用户无法打开图形界面问题 问题描述&#xff1a; 在 Linux 系统中&#xff0c;当我们远程SSH尝试以 root 用户身份运行需要图形界面的应用程序时&#xff0c;可能会遇到以下错误信息&#xff1a; MoTTY X11 proxy: Unsupported authorisati…

【开源项目-爬虫】Firecrawl

看到其他项目引用了这个项目 Firecrawl 用免费额度试了一下&#xff0c;这个项目和之前的 https://r.jina.ai/ 很像&#xff08;类似的还有 https://www.scrapingbee.com/&#xff1f;&#xff09;&#xff0c;将爬取到的网页转换为 markdown 格式&#xff0c;这样大语言模型用…