Mysql的UPDATE(更新数据)详解
MySQL的UPDATE语句是用于修改数据库表中已存在的记录,本文将详细介绍UPDATE语句的基本语法、高级用法、性能优化策略以及注意事项,帮助您更好地理解和应用这一重要的SQL命令。
1. 基本语法
单表更新
单表更新的基本语法如下:
UPDATE [LOW_PRIORITY] [IGNORE] table_name
SET column1 = value1, column2 = value2, ...
[WHERE condition]
[ORDER BY ...]
[LIMIT row_count]
- LOW_PRIORITY:如果指定了
LOW_PRIORITY选项,那么UPDATE操作会被推迟,直到没有其他客户端正在从该表中读取数据为止。 - IGNORE:如果指定了
IGNORE选项,那么在遇到错误时(如主键或唯一索引冲突),UPDATE操作不会中断,而是会发出警告。 - table_name:要更新的表的名称。
- SET column1 = value1, column2 = value2, …:指定要更新的列及其新的值。可以同时更新多个列,用逗号
,分隔。 - WHERE condition:可选的,用来指定应该更新哪些行。如果没有
WHERE子句,那么表中的所有行都会被更新。 - ORDER BY …:可选的,用来指定更新行的顺序。
- LIMIT row_count:可选的,用来限制最多更新多少行。
示例
-- 更新表 students 中 id 为 1 的记录,将 name 字段设为 '张三'
UPDATE students
SET name = '张三'
WHERE id = 1;-- 更新表 students 中所有记录,将 age 字段增加 1
UPDATE students
SET age = age + 1;
2. 高级用法
使用表达式更新
-- 将表 students 中所有记录的 age 字段增加 1
UPDATE students
SET age = age + 1;
使用子查询更新
-- 将表 students 中 name 为 '张三' 的记录的 class_id 更新为表 classes 中 name 为 '数学班' 的 class_id
UPDATE students
SET class_id = (SELECT id FROM classes WHERE name = '数学班')
WHERE name = '张三';
更新多表
-- 更新表 orders 和 order_details,将订单总金额大于 1000 的订单状态设置为 '已完成'
UPDATE orders o
JOIN order_details od ON o.order_id = od.order_id
SET o.status = '已完成'
WHERE o.total_amount > 1000;
使用 CASE 语句
-- 根据学生的年龄更新他们的等级
UPDATE students
SET grade = CASEWHEN age < 18 THEN '初级'WHEN age BETWEEN 18 AND 25 THEN '中级'ELSE '高级'
END;
使用 IF 语句
-- 根据学生的成绩更新他们的状态
UPDATE students
SET status = IF(score >= 60, '及格', '不及格');
使用 CONCAT 函数
-- 在学生的姓名后面添加 '同学'
UPDATE students
SET name = CONCAT(name, '同学');
使用 REPLACE 函数
-- 将学生的姓名中的 '张' 替换为 '李'
UPDATE students
SET name = REPLACE(name, '张', '李');
使用 COALESCE 或 IFNULL 处理 NULL 值
-- 如果学生的成绩为 NULL,则将其设为 0
UPDATE students
SET score = COALESCE(score, 0);
3. 性能优化策略
使用索引
在WHERE子句中使用索引字段可以显著加快数据检索速度。确保更新条件中的字段有适当的索引。
-- 假设 id 字段有索引
UPDATE students
SET name = '张三'
WHERE id = 1;
批量更新
如果需要更新多条记录,可以考虑将多个UPDATE语句合并为一个,减少事务开销。
-- 批量更新多个记录
UPDATE employees
SET salary = CASEWHEN id = 1 THEN 50000WHEN id = 2 THEN 60000WHEN id = 3 THEN 70000ELSE salary
END
WHERE id IN (1, 2, 3);
避免全表更新
尽量避免不带WHERE子句的UPDATE语句,因为这会导致全表更新,消耗大量资源。
-- 避免这种写法
UPDATE employees
SET salary = 50000;
使用 LIMIT
在某些情况下,可以使用LIMIT限制更新行数,特别是当更新操作可能导致锁竞争时。
-- 限制更新行数
UPDATE employees
SET salary = 50000
WHERE id > 1000
LIMIT 100;
优化事务
对于大批量更新操作,可以考虑将更新分批进行,每批更新后手动提交事务,避免长时间锁表。
START TRANSACTION;
UPDATE employees
SET salary = 50000
WHERE id BETWEEN 1 AND 1000;
COMMIT;START TRANSACTION;
UPDATE employees
SET salary = 50000
WHERE id BETWEEN 1001 AND 2000;
COMMIT;
4. 注意事项
- 备份数据:在执行大规模或重要的更新操作之前,建议先备份数据。
- 使用事务:对于复杂的更新操作,建议使用事务来确保数据的一致性和完整性。
- 性能考虑:更新大量数据时,应考虑索引的使用和锁定机制的影响。
- 数据一致性:确保更新操作不会导致数据不一致或违反业务规则。
5. 实战示例
假设我们有一个 employees 表,包含以下字段:id, name, salary, department_id。以下是一些实战示例:
更新特定员工的工资
-- 将 id 为 1 的员工的工资设为 60000
UPDATE employees
SET salary = 60000
WHERE id = 1;
更新多个员工的工资
-- 将部门为 10 的所有员工的工资增加 10%
UPDATE employees
SET salary = salary * 1.1
WHERE department_id = 10;
更新员工的部门
-- 将 id 为 1 的员工的部门设为 20
UPDATE employees
SET department_id = 20
WHERE id = 1;
使用子查询更新员工的部门
-- 将 id 为 1 的员工的部门设为 '研发部' 的部门 ID
UPDATE employees
SET department_id = (SELECT id FROM departments WHERE name = '研发部')
WHERE id = 1;
更新多个字段
-- 将 id 为 1 的员工的名字设为 '李四',工资设为 70000
UPDATE employees
SET name = '李四', salary = 70000
WHERE id = 1;
6. 总结
MySQL的UPDATE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量更新、避免全表更新、使用LIMIT以及优化事务,可以显著提高UPDATE语句的执行效率。
相关文章:
Mysql的UPDATE(更新数据)详解
MySQL的UPDATE语句是用于修改数据库表中已存在的记录,本文将详细介绍UPDATE语句的基本语法、高级用法、性能优化策略以及注意事项,帮助您更好地理解和应用这一重要的SQL命令。 1. 基本语法 单表更新 单表更新的基本语法如下: UPDATE [LOW…...
基于Java Springboot高校奖助学金系统
一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术:Html、Css、Js、Vue、Element-ui 数据库:MySQL 后端技术:Java、Spring Boot、MyBatis 三、运行环境 开发工具:IDEA/eclipse 数据…...
如何在 Ubuntu 22.04 上安装带有 Nginx 的 ELK Stack
今天我们来聊聊如何在 Ubuntu 22.04 服务器上安装 ELK Stack,并集成 Nginx 作为 Web 服务器,同时使用 Let’s Encrypt Certbot 进行 SSL 认证。ELK Stack,包括 Elasticsearch、Logstash 和 Kibana,是一套强大的工具,用…...
Python爬虫:深入探索1688关键词接口获取之道
在数字化经济的浪潮中,数据的价值愈发凸显,尤其是在电商领域。对于电商平台而言,关键词不仅是搜索流量的入口,也是洞察市场趋势、优化营销策略的重要工具。1688作为中国领先的B2B电商平台,其关键词接口的获取对于商家来…...
Let‘s Encrypt SSL证书:acmessl.cn申请免费3个月证书
目录 一、CA机构 二、Lets Encrypt特点 三、申请SSL 一、CA机构 Lets Encrypt是一个由非营利组织Internet Security Research Group (ISRG)运营的证书颁发机构(CA),旨在通过自动化和开放的方式为全球网站提供免费、可靠的SSL/TLS证书。…...
JSON Web Token (JWT)的简单介绍、验证过程及令牌刷新思路
目录 一、JWT 1、什么是Jwt 2、为什么要使用Jwt 3、应用场景 4.Jwt的组成 4.1、Header 4.2、Payload 4.3、signature 二、Jwt验证过程 1、生成Jwt令牌 2、解析旧的Jwt 3、复制Jwt 4、Jwt有效时间测试 三、Jwt令牌刷新思路 1、配置JwtFilter过滤器 2、登录生成Jwt令…...
xxl-job入门
xxl-job , 定时任务 分布式 , 带来的问题的 解决方案 像之前 很多项目都用到定时任务, 但是如果要改为 分布式, 那么定时任务 就要用到 xxl-job 1.用户画像 拼多多,看了某个东西后,推荐类似东西, 做埋…...
100.【C语言】数据结构之二叉树的堆实现(顺序结构) 1
目录 1.顺序结构 2.示意图 编辑 从物理结构还原为逻辑结构的方法 3.父子节点编号的规律 4.顺序存储的前提条件 5.堆的简介 堆的定义 堆的两个重要性质 小根堆和大根堆 6.堆的插入 7.堆的实现及操作堆的函数 堆的结构体定义 堆初始化函数HeapInit 堆插入元素函…...
大模型 VS 大语言模型
最近很多朋友搞不懂大模型和大预言模型的区别,总是把大模型就认为是大语言模型。 今天就用这篇帖子做一个科普。 大模型 概念:大模型是指拥有超大规模参数(通常在十亿个以上)、复杂计算结构的机器学习模型。它通常能够处理海量数…...
Linux高阶——1117—TCP客户端服务端
目录 1、sock.h socket常用函数 网络初始化函数 首次响应函数 测试IO处理函数 获取时间函数 总代码 2、sock.c SOCKET() ACCEPT()——服务端使用这个函数等待客户端连接 CONNECT()——客户端使用这个函数连接服务端 BIND()——一般只有服务端使用 LISTEN()——服务端…...
【Qt】Qt 在main.cpp中使用tr()函数报错
1. 问题 Qt 在main.cpp中使用tr()报错。 error: tr was not declared in this scope2. 解决方法 main.cpp中注意如下: //添加头文件 #include <QObject>//添加QObject QObject::tr("Hello")3. 参考 Qt tr()函数不起效的小问题...
面向对象高级(5)接口
面向对象高级(5) 接口 接口就是规范,定义的是一组规则,体现了现实世界中“如果是...则必须能...”的思想。继承是一个"是不是"的is-a关系,而接口实现则是 "能不能"的has-a关系。 1、接口的定义格…...
uniapp发布android上架应用商店权限
先看效果: 实现原理: 一、利用uni.addInterceptor的拦截器,在一些调用系统权限前拦截,进行弹窗展示,监听确定取消实现业务逻辑。 二、弹窗是原生nativeObj进行drawRect绘制的 三、权限申请调用使用的 plus.android.…...
Centos Stream 9安装Jenkins-2.485 构建自动化项目步骤
官网:https://www.jenkins.io/ 1 下载 环境准备: 版本支持查询:https://pkg.jenkins.io/redhat-stable/ 安装JDK17:https://blog.csdn.net/qq_44870331/article/details/140784297 yum -y install epel-release wget upgradew…...
电路模型和电路定理(二)
电路元件 是电路中最基本的组成单元。 电阻元件:表示消耗电能的元件 电感元件:表示产生磁场,储存磁场能的元件 电容元件:表示产生电场,储存电场能量的元件 电压源和电流源:表示将其他形式的能量转变成…...
瑞佑液晶控制芯片RA6807系列介绍 (三)软件代码详解 Part.10(让PNG图片动起来)完结篇
RA6807是RA8876M的缩小版,具备RA8876M的所有功能,只将MCU控制接口进行缩减,仅保留SPI-3和I2C接口,其它功能基本相同。 该芯片最大可控制854x600的分辨率,内建64Mbits显存,多个图层,使用起来相当…...
Qt常用控件 按钮
文章目录 1. QAbstractButton 简介2. QPushButton2.1 例子1,设置按钮的图标2.2 例子2,设置按钮快捷键 3. QRadioButton3.1 介绍3.2 例子1,选择性别3.3 例子2,试试其他的信号3.3 例子3,分组 4. QCheckBox4.1 介绍4.2 例…...
MySQL学习/复习10视图/用户/权限/语言连接数据库
一、视图 1.1创建视图 1.2视图影响基表 1.3基表影响视图 1.4删除视图 1.5视图使用规则 二、数据库的用户 2.1mysql中的user表 注意事项:主机/用户名/密码/权限 2.2用户的创建 注意事项:设置密码与登录地点需谨慎 2.3删除用户 注意事项:% 2.4…...
vulfocus在线靶场:tomcat-pass-getshell 弱口令 速通手册
目录 一、启动环境,访问页面,并登录,账号密码都是tomcat 二、哥斯拉打war包,图解 三、上传war包,图解 四、访问我们直接url/木马文件名/木马文件.jsp,是否存在了 五、 哥斯拉测试连接结果success&…...
c#:winform调用bartender实现打印(学习整理笔记)
效果 学习路径 C# winform调用Bartender进行自定义打印、批量打印、检索文件夹中的模板_哔哩哔哩_bilibili 一、初始环境搭建见: c#:winform引入bartender-CSDN博客https://blog.csdn.net/weixin_46001736/article/details/143989473?sharetypeblogdetail&s…...
2025年能源电力系统与流体力学国际会议 (EPSFD 2025)
2025年能源电力系统与流体力学国际会议(EPSFD 2025)将于本年度在美丽的杭州盛大召开。作为全球能源、电力系统以及流体力学领域的顶级盛会,EPSFD 2025旨在为来自世界各地的科学家、工程师和研究人员提供一个展示最新研究成果、分享实践经验及…...
Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...
聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...
【2025年】解决Burpsuite抓不到https包的问题
环境:windows11 burpsuite:2025.5 在抓取https网站时,burpsuite抓取不到https数据包,只显示: 解决该问题只需如下三个步骤: 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...
MySQL 8.0 OCP 英文题库解析(十三)
Oracle 为庆祝 MySQL 30 周年,截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始,将英文题库免费公布出来,并进行解析,帮助大家在一个月之内轻松通过OCP认证。 本期公布试题111~120 试题1…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...
Redis:现代应用开发的高效内存数据存储利器
一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发,其初衷是为了满足他自己的一个项目需求,即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源,Redis凭借其简单易用、…...
【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
yaml读取写入常见错误 (‘cannot represent an object‘, 117)
错误一:yaml.representer.RepresenterError: (‘cannot represent an object’, 117) 出现这个问题一直没找到原因,后面把yaml.safe_dump直接替换成yaml.dump,确实能保存,但出现乱码: 放弃yaml.dump,又切…...
跨平台商品数据接口的标准化与规范化发展路径:淘宝京东拼多多的最新实践
在电商行业蓬勃发展的当下,多平台运营已成为众多商家的必然选择。然而,不同电商平台在商品数据接口方面存在差异,导致商家在跨平台运营时面临诸多挑战,如数据对接困难、运营效率低下、用户体验不一致等。跨平台商品数据接口的标准…...
