首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL这样写UPDATE语句,劝退

# 起因 最近,好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新… # 结论 小结:在一条UPDATE语句中,如果要更新多个字段...# 现象 刚遇到这个问题的时候,我拿到这条语句直接在测试库里面执行了一把,发现确实有问题,但和开发描述的还是有区别,这里我用测试数据来模拟下: 有问题的SQL语句update apps set owner_code...分析 看起来,语法是完全没有问题,翻了翻MySQL官方文档的update语法: 看到assignment_list的格式是以逗号分隔的col_name=value列表,一下子豁然开朗,开发同学想要的多字段更新语句应该这样写...小结:在一条UPDATE语句中,如果要更新多个字段,字段间不能使用“AND”,而应该用逗号分隔。...因此,这个逻辑表达式的结果为false,false在MySQL中等价于0!

3.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL这样写UPDATE语句,劝退

    来自:ju.outofmemory.cn/entry/336774 最近好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新...刚遇到这个问题的时候,我拿到这条语句直接在测试库里面执行了一把,发现确实有问题,但和开发描述的还是 有区别 ,这里我用测试数据来模拟下: 有问题的SQL语句 执行之前的记录是这样的: 执行之后的记录是这样的...看起来,语法是完全没有问题,翻了翻MySQL官方文档的update语法: 看到assignment_list的格式是以逗号分隔的col_name=value列表,一下子豁然开朗,开发同学想要的多字段更新语句应该这样写...小结 : 在一条UPDATE语句中,如果要更新多个字段,字段间不能使用“AND”,而应该用逗号分隔。...因此,这个逻辑表达式的结果为 false , false在MySQL中等价于0!

    3.9K40

    MySQL Update语句是怎么执行的?

    MySQL Update语句是怎么执行的?...[isd2tnp037.png] 昨天,我们利用这张图,了解了一个select语句的执行过程,讲解了连接器、查询缓存、分析器、优化器、执行器等模块的作用,今天我们来看一条update语句是怎么执行的...其实,update语句的执行过程和select语句差不多,但是在update语句执行的过程中,MySQL新增加了两个重要的日志模块,他们分别是redo log(重做日志)和binlog(二进制日志、也可以称之为归档日志...关于redo log,之前我们在文章中也有讲过,欢迎翻看: 《Mysql中的Redo Log解析(一)》 《Mysql中的Redo Log解析(二)》 《MySQL中的Redo Log(三)》 我们知道...当我们执行一个update的SQL时,MySQL会干如下几件事情: a、执行器查找指定记录,如果记录所在的数据页在内存中,就直接返回给执行器;否则,需要先从磁盘读入内存,然后再返回。

    4.5K40

    Hue执行多条语句问题

    之前有遇到impala-shell中多次执行drop和create语句,由于impalad更新元数据有几秒的延迟,所以会出现 Tablealready exists的情况,于是加上了 setSYNC_DDL...=1;语句进行快速同步。...卡了一段时候之后,回头看了下hue的历史记录,发现drop table语句根据没有执行。这才猛然想起来,自己执行的时候没有选中所有语句,HUE提交SQL默认是只会执行最后一条SQL。...选中所有语句后,问题得以解决。 另外,SQL结尾处如果没有显式地增加分号结尾,那么即使全部选中之后再执行,Hue也会将三个SQL当成一条SQL来执行,而不是按照换行符进行分割。...因此当我们要批量执行多条SQL的时候,一定要在每条SQL的结尾处加上分号。

    2.5K30

    深入理解MySQL中的UPDATE JOIN语句

    MySQL数据库中,UPDATE语句用于修改表中现有的记录。有时,我们需要根据另一个相关联表中的条件来更新表中的数据。这时就需要使用UPDATE JOIN语句。...为了处理历史数据,我们使用了update join语句。 什么是UPDATE JOIN? UPDATE JOIN语句允许我们使用一个表的数据来更新另一个相关联的表的数据。...测试更新操作:在执行UPDATE JOIN语句之前,最好先在测试环境中进行测试,确保更新操作不会对数据产生不良影响。...总结 在本文中,我们深入探讨了MySQLUPDATE JOIN语句的概念、语法和示例用法。...但是在使用UPDATE JOIN时需要谨慎,确保连接条件和WHERE子句的准确性,以避免意外的结果。希望本文能够帮助你更好地理解和应用UPDATE JOIN语句

    27110

    mysql中一条insert语句批量插入多条记录

    插入语句常用写法: INSERT INTO items(name,city,price,number,picture) VALUES('耐克运动鞋','广州',500,1000,'003.jpg');...这种方式只能够一次插入一条数据,要想插入多条数据,就得多次调用此sql语句,意味着多次与数据库建立连接。...幸好MySQL提供了另一种解决方案,就是使用一条INSERT语句来插入多条记录。这并不是标准的SQL语法,因此只能在MySQL中使用。...])); 可以看到,和原来的常规INSERT语句的区别,仅仅是在VALUES 后面增加值的排列,每条记录之间用英文输入法状态下的逗号隔开,是不是so easy。...建议: 在程序中,插入批量数据时,最好使用这种通过一条INSERT语句来一次性插入的方式。这样可以避免程序和数据库建立多次连接,从而增加服务器负荷。

    5.1K20

    如何实现update select 语句

    如何实现update select 语句 前言: 有些时候我们会遇到如下情况,我们需要依赖一张表的查询结果来更新另一张表,比如我们存在一张主表和一张关联表,我们需要把关联表的部分字段数据同步到主表的里面...处理方式也比较简单,直接使用sql就可以完成,这篇文章针对这个小需求,总结一下update select 的几种实现方式。...文章目的: 实现update select 的几种常见方法 join merge 子查询 merge的踩坑和问题 准备数据 为了更好的进行实际操作,这里构建两张简单的表来模拟场景。...UPDATE olddb ALIAS SET ( new_field ) = ( SELECT ( bb.new_field ) FROM olddb aa JOIN newdb bb...update select的实现实际情况复杂多变,这里只列举了最简单的使用情况。

    4.7K20

    【面试题精讲】mysql-update语句执行流程

    什么是 update 语句update 语句:是一种用于修改数据库表中的数据记录的 SQL(Structured Query Language,结构化查询语言)操作语句。...它可以对表中的单条或多条数据记录进行内容更新,支持输入的新数据值来自常量、计算结果或其他表中的数据。...在执行 update 语句时,MySQL 会根据条件筛选出需要更新的记录,然后逐行修改记录中的数据。 2. 为什么需要 update 语句update 语句的存在,体现了数据库的动态性。...update 语句的执行流程大致如下: 解析 SQL 语句:对给定的 update 语句进行解析,提取表名、操作字段(列名)、更新值、条件等信息; 锁定表:为了保证数据的一致性,在 update...在多条件查询中,注意使用 合适的索引,以提高 update 语句的执行速度。

    21010

    【面试题精讲】mysql-update语句执行流程

    什么是 update 语句update 语句:是一种用于修改数据库表中的数据记录的 SQL(Structured Query Language,结构化查询语言)操作语句。...它可以对表中的单条或多条数据记录进行内容更新,支持输入的新数据值来自常量、计算结果或其他表中的数据。...在执行 update 语句时,MySQL 会根据条件筛选出需要更新的记录,然后逐行修改记录中的数据。 2. 为什么需要 update 语句update 语句的存在,体现了数据库的动态性。...update 语句的执行流程大致如下: 解析 SQL 语句:对给定的 update 语句进行解析,提取表名、操作字段(列名)、更新值、条件等信息; 锁定表:为了保证数据的一致性,在 update...在多条件查询中,注意使用 合适的索引,以提高 update 语句的执行速度。

    30820

    数据库update语法-MySQL数据库 | SQL语句详解

    MySQL数据库基本操作——DDL   DDL解释:   1.数据库的常用操作   2.表结构的常用操作   3.修改表结构   数据库的常用操作 查看所有的数据库show ;   创建数据库   ...varchar(20), address varchar(20) );   修改表结构 表结构的常用操作 查看当前数据库所有的表show tables;   查看指定表的创建语句...数据库update语法,列2数据库update语法,列3…) value(值1,值1,值1…);   2.向表中插入所有列   insert into 表 value(值1,值1,值1…);   ...) update 表名 set 字段名=值,字段名=值…;   update 表名 set 字段名=值,字段名=值… where 条件;    update stu set address...= '武汉'; update stu set address = '北京' where sid = 001; update stu set

    1.9K20

    一文看懂MySQL执行update更新语句的流程

    MySQL可以恢复到半月内任意一秒的状态!如何做到的? 得从一个表的一条更新语句说起。 创建一个男人表,主键id和整型字段age: ? 插俩数据。 ? 将id=2这一行的值加1 ?...SQL语句基本的执行流程同样适用于更新语句。...执行语句前要先通过连接器连接数据库 表上有更新时,此表有关查询缓存就会失效,所以这条语句就会把表man上所有缓存置空 分析器会通过词法和语法解析知道这是一条更新语句 优化器决定使用id索引 执行器负责具体执行...看执行器和InnoDB引擎在执行这个简单的update语句时的内部流程。 执行器先找引擎取id=2这行。id是主键,引擎直接用b+树搜索。...假设当前ID=2的行,字段c的值是0,再假设执行update语句过程中,在写完第一个日志后,第二个日志还没有写完期间发生crash?

    3.4K10

    mysql update语句和原数据一样会更新么

    平常使用 mysql ,必不可少的会用到 update 语句,不知道小伙伴有没有这样的疑问? 如果 update 语句和原数据一样会更新么?...更具体的来说,如果更新的数据前后是一样的,MySQL 会更新存储引擎中(磁盘)数据么? 关于这个问题,在分析之前我们可以思考下:update语句和原数据一样,有必要更新么?理论上来讲是没有必要的。...MySQL Server 层在执行 sql 时,其实是不知道是否是一样的,因此可以猜想,如果 MySQL 已经知道原数据的话,这样可以和 update 语句做对比,这样一样的话可以不用更新了。...那么 MySQL 在执行update 语句时,什么时候会读取原数据呢?...row 格式的 binlog 会记录镜像数据,针对 update 来说,必须是前镜像数据才能判断出来update 语句是否和原数据一样。

    1.7K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券