记一次MySQL更新语句update的踩坑
作者:JavaGeekers 发布时间:2024-01-16 19:35:29
标签:MySQL,更新语句,update
背景
最近在一次线上作业过程中执行了一句DML语句,本以为万无一失,结果应用反馈说没有更新,数据还是没有变,最后经过排查才发现是我语句写错了,导致update语句执行的结果与预期不符。
情景再现
为了方便演示,建立一张用户表,同时插入五条数据。
create table user(
id int(12) comment '用户主键id',
name varchar(36) comment '用户名',
age int(12) comment '年龄');
insert into user values (1,'one',11),(2,'two',12),(3,'three',13),(4,'four',15),(5,'five',15);
执行完成后,现在user表中的数据如下:
+------+-------+------+
| id | name | age |
+------+-------+------+
| 1 | one | 11 |
| 2 | two | 12 |
| 3 | three | 13 |
| 4 | four | 15 |
| 5 | five | 15 |
+------+-------+------+
现在需要把所有的年龄改成 10、用户名改成user——假设此操作有意义——我提交到运维的 DML 语句如下:
update user set age=10 and name='user';
当我刷新用户表,看到执行update语句后的表全部数据如下:
+------+-------+------+
| id | name | age |
+------+-------+------+
| 1 | one | 0 |
| 2 | two | 0 |
| 3 | three | 0 |
| 4 | four | 0 |
| 5 | five | 0 |
+------+-------+------+
神奇的事情发生了,age字段全部被更新成0,而name字段竟然没有任何修改!
错误原因及修正
错误原因其实很简单,update语句写错了。MySQL中update语句的语法是
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;
```sql
如果更新多个字段,相邻字段间应该以逗号分隔而不是`and`。如果 update 语句使用 and 作为多个字段之间的分隔符,就像最开始我提交给运维的那样,这个更新语句最终将会变成
```sql
update user set age=(10 and name='user');
而(10 and name='user')作为一个返回值为 boolean 类型的判断语句,返回会被映射成 1 或 0,有 99.999% 的可能会让第一个更新变量更新为错误的数据。
正确的更新语句应该是
update user set age=10, name='user';
教训
在提交DML语句前先在测试环境试一下
基础的SQL语法不要记错
小结
MySQL中update语句的语法是
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;
来源:https://javageekers.club/archives/mysql-update
0
投稿
猜你喜欢
- python新手一枚,操作系统Win10 64 bit,Python版本,3.7因为某个脚本需要用到win32con 和win32api模块
- 一、背景 最近系统线上数据库数据出现一个问题,发现某些字段存在一些异常的首尾空格,不管
- 一、下载安装官网下载社区版dmg安装文件: https://dev.mysql.com/downloads/mysql/1、执行安装文件,按
- 概述pandas中与库版本或依赖库版本相关的API主要有以下4个:pandas.__version__:查看pandas简要版本信息。pan
- Vue添加全局store在命令行中输入安装npm install --save vuex在main.js文件中引用store和在new Vu
- 1、场景1)用户输入完网址后,浏览器直接弹出需要输入用户名/密码PS:此时输入用户名密码即可登录,或者直接带着用户名密码访问网站。假设url
- 一、网络结构的可视化我们训练神经网络时,除了随着step或者epoch观察损失函数的走势,从而建立对目前网络优化的基本认知外,也可以通过一些
- 1.导言现今的公司需要易访问的和可用性好的商业数据,以便他们可以在全球市场中获得一席之地。与易访问数据的这个需求相呼应的,关系数据库和分析数
- 介绍Trie树:又称为单词查找树,是一种树形结构,可以应用于统计字符串,会在搜索引擎系统中用于对文本的词频统计,下图是一个Trie树的结构,
- 主键的生成方式主要有三种: 一. 数据库自动生成 二. GUID 三. 开发创建 严格讲这三种产生方式有一定的交叉点,其定位方式将在下面进行
- 前言本章我们来介绍如何使用Pytorch训练一个区分不同音频的分类模型,例如你有这样一个需求,需要根据不同的鸟叫声识别是什么种类的鸟,这时你
- 一、问题开发中遇到将其它数据库数据插入到mysql数据库表中一直会报类似如下错误:Incorrect string value: '
- 12306火车票购票软件大家都用过,怎么用Python写一个命令行的火车票查看器,要求在命令行敲一行命令来获得你想要的火车票信息,下面通过本
- 引言:最近邻插值Nearest Neighbour Interpolate算法是图像处理中普遍使用的图像尺寸缩放算法,由于其实现简单计算速度
- 很多朋友问到sql server数据库”生成脚本”,只导出了数据库的sql脚本,而表里的数据依然没有导出来。很简单,看教程:注:我这里用的S
- 在命令行中运行python代码是很常见的,下面介绍如何定义命令后面跟的参数。1 常规用法Python代码中主要使用下面
- 实现功能excel表格中有4列数,分别为RMF计算得到的 β,γ,势能面及组态,需要挑选出相同 β 值下势能面最低时的组态。为了减小数据量,
- 如下所示:import time首先导入时间模块在程序开始执行的地方写入:start=time.clock()在程序末尾写入:end=tim
- 写在最前面:带你从最简单的二叉树构造开始,深入理解二叉树的数据结构,ps:不会数据结构的程序猿只能是三流的首先,我们构造一个二叉树这是最标准
- 封装为了jq插件,如下drag.js;(function ($) { $.fn.dragDiv = function (options) {