我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL update set 和 and的区别

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL update set 和 and的区别

问题描述

最近接到一个奇怪的咨询,update 语句执行没有报错,但是没有更新数据,具体有问题的语句类似于如下形式:


update test.stu set cname = '0' and math = 90 and his = 80 where id = 100;

原因分析

直观上看,这个 update 语句的语法是有问题的,正常更新多列数据的语法应该是用逗号,类似于如下形式:


update test.stu set cname = '0',math = 90,his = 80 where id = 100;

直接用 and 第一反应其实是会报语法错误,不太像是能正常执行的。那么基于腾讯云数据库 MySQL,实际构造一个简单的场景,尝试复现一下这个问题。

SQL 语句如下:


CREATE TABLE `stu` (
  `id` int(11) NOT NULL,
  `sname` varchar(16) NOT NULL,
  `cname` varchar(8) DEFAULT NULL,
  `math` int(11) NOT NULL,
  `eng` int(11) DEFAULT NULL,
  `his` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

insert into stu values(100,'sam','0',90,88,83);
insert into stu values(101,'jhon','1',97,82,81);
insert into stu values(102,'mary','2',87,89,92);
insert into stu values(103,'adam','2',87,89,92);

然后分别试一试正常的 update 语句和使用 and 的 update 语句,看一下实际的运行结果:


mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update test.stu set cname = '0' and math = 90 and his = 80 where id = 100;
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1  Changed: 0  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> update test.stu set cname = '0',math = 90,his = 80 where id = 100;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   80 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.01 sec)

mysql>

可以看到这两个语句确实都不会报错,且带 and 的 update 语句匹配到了具体的行(Rows matched: 1),但是没有修改数据(Changed: 0),标准语法下的 update 语句倒是正常修改了数据。

由此可见,MySQL 在语法上,并不认为 and 这个用法是错误的,那么说明 MySQL 用另外的方式“解读”了这个语句。最容易想到的,就是 MySQL 是不是在 set 的时候,把 and 解释成了逻辑运算符,而不是英文意义上的“和”?而且 cname 的取值本来就是 0,也符合数据库处理 bool 数据时的行为(用 0 和 1 代替 False 和 True)。

验证起来很简单,换个 cname 不为 0 的数据 update 一下就可以了:


mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 1     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> begin;update test.stu set cname = '0' and math = 90 and his = 80 where id = 101;
Query OK, 0 rows affected (0.00 sec)

Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from stu;
+-----+-------+-------+------+------+------+
| id  | sname | cname | math | eng  | his  |
+-----+-------+-------+------+------+------+
| 100 | sam   | 0     |   90 |   88 |   83 |
| 101 | jhon  | 0     |   97 |   82 |   81 |
| 102 | mary  | 2     |   87 |   89 |   92 |
| 103 | adam  | 2     |   87 |   89 |   92 |
+-----+-------+-------+------+------+------+
4 rows in set (0.00 sec)

mysql> rollback;
Query OK, 0 rows affected (0.00 sec)

从结果来看,MySQL 修改 cname 的值为 0,说明确实是当成逻辑运算符来处理了,仔细分析这个语句,会发现 MySQL 按照如下方式来处理:


set cname = ('0' and math = 90 and his = 80)

math 和 his 的取值是根据 where 条件筛选的行来决定的,实际对应到上面测试的场景,会变成如下的逻辑判断:


'0' and 97 = 90 and 81 = 80

PS:需要注意,即便是字符型的数据 0,也会被当做 False。

解决方案

目前并不能通过 sql_mode 或者其他参数的形式来阻止这种带 and 的 update 语句,因此这一类问题的隐蔽性比较强。建议在开发的时候,利用封装好的框架,或者加强代码或者 SQL review 来避免这个问题。

PS:腾讯云数据库 MySQL 也会有类似的问题,需要警惕。

以上就是MySQL update set 和 and的区别的详细内容,更多关于MySQL update set 和 and的资料请关注自学编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL update set 和 and的区别

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL update set 和 and的区别

问题描述最近接到一个奇怪的咨询,update 语句执行没有报错,但是没有更新数据,具体有问题的语句类似于如下形式:update test.stu set cname = '0' and math = 90 and his = 80 wher
2022-05-14

MySQL中update set和and的区别有哪些

这篇文章主要介绍了MySQL中update set和and的区别有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。问题描述最近接到一个奇怪的咨询,update 语句执行没有
2023-06-14

sql中or和and的区别

or 和 and 运算符在 sql 中用于组合布尔表达式,返回 true 或 false。and 仅当所有表达式为 true 时为 true;or 当至少一个表达式为 true 时为 true。SQL 中 OR 和 AND 的区别在 SQ
sql中or和and的区别
2024-05-12

python集合set中add与update区别有哪些

这篇文章主要介绍了python集合set中add与update区别有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。集合set是一个无序不重复元素的集set([hello,
2023-06-08

sql中and和or的区别

sql 中 and 和 or 的区别:and 将布尔表达式连接时要求所有条件都满足才返回 true,缩小查询结果。or 将布尔表达式连接时要求任意一个条件满足就返回 true,扩大查询结果。SQL 中 AND 和 OR 的区别在 SQL
sql中and和or的区别
2024-05-08

SQL 中 ALTER 和 UPDATE 命令的区别

在这篇文章中,我们将了解 ALTER 命令和 UPDATE 之间的区别command in SQL.ALTER命令此命令是数据定义语言(DDL)。它在结构级别上执行操作,而不是数据级别。此命令用于在数据库中添加、删除和修改表的属性。此命令
2023-10-22

SQL查询中between and和and的区别是什么

在SQL查询中,"between and"和"and"是两种不同的语法结构,具有不同的用途和效果。1. "between and":是用于指定一个范围的条件。它用于在查询中筛选出一个范围内的值。语法如下:```sqlSELECT colum
2023-08-19

sql中and和or的用法区别

sql中and和or运算符用于组合条件,实现and和or逻辑运算。and运算符要求所有条件都为真,而or运算符要求至少一个条件为真。使用括号可控制运算顺序,复杂查询中可结合使用and和or运算符获得所需逻辑结果。SQL 中 AND 和 OR
sql中and和or的用法区别
2024-05-12

idea中git pull和update project区别

区别有:1.性质不同;2.作用不同;3.两者含义不同。性质不同指,git pull是Git的原生命令;而update project不是Git的原生命令,是IDEA对Git的封装扩展。作用不同指,git pull的作用是从远程分支上拉取最新版本代码到本地,并自动合并merge到当前分支;而update project会更新项目所有module。
idea中git pull和update project区别
2023-10-29

Vue.set()和this.$set()的区别是什么

Vue.set()和this.$set()的区别是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。data () { return { student: {
2023-06-15

sql中and和or的区别是什么

在SQL中,AND和OR是用于连接多个条件的逻辑运算符。AND:当使用AND连接多个条件时,只有当所有条件同时成立时,整个条件才会被满足。换句话说,所有条件必须为真才会返回True。例如:SELECT * FROM table_name W
sql中and和or的区别是什么
2024-04-09

php中get和set的区别是什么

php中get和set的区别:“__get()”方法是用于获取私有成员属性值的,返回的结果是获取到的属性值,而“__set()”方法是用于设置私有成员属性值的,该方法没有返回值。
2014-11-04

java中set和list的区别是什么?

Java中的集合共包含三大类,它们分别是Set(集),List(列表)以及Map(映射)。它们都处在java.util中并且都为接口。它们各自都有各自的实现类。下面给大家介绍一下set和list的区别,希望对大家有所帮助。java中set和list的区别1、重
java中set和list的区别是什么?
2020-08-03

编程热搜

目录