首页
学习
活动
专区
工具
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.1K20

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.4K40

Mysql查询语句优化

前言 上一篇文章 《MySQL索引原理机器优化》讲了索引的一些原理以及优化方案,这一次学习对查询的优化,毕竟快速的查找到数据才是我们的最终目的....分析查询 想要对一条查询语句进行优化,首先要对其进行分析,MySQL提供了这个机制, 可以通过explain sql 或者desc sql的语法去获取MySQL对某一条语句的执行计划(MySQL优化之后的...查询优化 对一条sql的优化可以分为两部分,第一部分是对语句优化,比如将子查询改写为join等,第二部分是与索引相关的优化,在这一阶段可能会修改语句以让查询尽可能的命中索引,甚至会通过修改索引来达到这个目的...查询语句优化 检查语句 查询语句优化的第一步,首先从大的层面上分析一下语句,得到以下问题的答案: 是否请求了不需要的数据?...STRAIGHT_JOIN 该hint告诉MySQL按照语句中的顺序进行多个表的关联操作,不要进行”优化”.select STRAIGHT_JOIN * from table1 join table2.

5.2K20

MySQL 语句优化 ICP

ICP介绍 Index Condition Pushdown(ICP)是MySQL 5.6中的的新特性,是一种在存储引擎层使用索引过滤数据的一种优化方式。...ICP可以减少存储引擎访问基表的次数以及MySQL服务器访问存储引擎的次数。 当MySQL使用索引从表中检索行时,索引条件下推(ICP)是一种优化。...table_condition_attached: 在attaching_conditions_to_tables阶段添加了附加条件的条件语句。 access_type:优化后的索引访问类型。...比如 select for update更新数据 ,ICP大大减少行锁的数量,因为行锁是在引擎层。...擅长MySQL、Redis、MongoDB数据库高可用设计和运维故障处理、备份恢复、升级迁移、性能优化。自学通过了MySQL OCP 5.6和MySQL OCP 5.7认证。

1.6K30

MySQL——优化ORDER BY语句

MySQL——优化ORDER BY语句 本篇文章我们将了解ORDER BY语句优化,在此之前,你需要对索引有基本的了解,不了解的老少爷们可以先看一下我之前写过的索引相关文章。现在让我们开始吧。...ORDER BY优化的核心原则 尽量减少额外的排序,通过索引直接返回有序数据。...ORDER BY优化实战 用于实验的customer表的索引情况: 首先要注意: MySQL一次查询只能使用一个索引,如果要对多个字段使用索引,建立复合索引。...根据两种排序算法的特性,适当加大系统变量maxlengthforsortdata的值,能够让MySQL选择更优化的Filesort排序算法。...并且在书写SQL语句时,只使用需要的字段,而不是SELECT * 所有的字段,这样可以减少排序区的使用,提高SQL性能。

1.1K21

mysql 语句如何优化

mysql 语句如何优化大家好,我是微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!...因此,优化MySQL语句是提升数据库性能和效率的关键一步。如何优化MySQL语句优化MySQL语句的方法有很多,以下是一些常见的技术和策略:1. 使用索引索引可以加快数据的检索速度。...避免全表扫描尽量避免使用没有条件的SELECT语句,以免触发全表扫描。应该根据业务需求设计具体的查询条件,限制返回数据的数量。3. 优化查询语句确保SQL语句的简洁性和效率。...使用EXPLAIN分析查询计划MySQL提供了EXPLAIN命令来分析查询语句的执行计划,可以帮助优化查询。...结论通过合理的SQL语句优化策略,可以显著提升MySQL数据库的性能和响应速度,降低系统负载,提高用户体验和系统稳定性。微赚淘客系统3.0小编出品,必属精品!

8610

深入理解MySQL中的UPDATE JOIN语句

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

21210

Mysql Join语句优化

尽可能减少Join语句中Nested Loop的循环总次数 最有效的办法是让驱动表的结果集尽可能地小,这也正是在本章第二节中所提到的优化基本原则之一——“永远用小结果集驱动大结果集” 比如,当两个表(表...优先优化Nested Loop的内层循环 不仅在数据库的Join中应该这样做,实际上在优化程序语言时也有类似的优化原则。...保证Join语句中被驱动表的Join条件字段已经被索引 其目的正是基于上面两点的考虑,只有让被驱动表的Join条件字段被索引了,才能保证循环中每次查询都能够消耗较少的资源,这也正是内层循环的实际优化方法...在这种情况下,Join Buffer的大小将对整个Join语句的消耗起到非常关键的作用

1.9K60

Mysql性能优化一:SQL语句性能优化

的效率,因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑,视具体情况而定。...存储过程是编译好、优化过、并且被组织到一个执行规划里、且存储在数据库中的SQL语句,是控制流语言的集合,速度当然快。反复执行的动态SQL,可以使用临时存储过程,该过程(临时表)被放在Tempdb中。...40,mysql查询优化总结:使用慢查询日志去发现慢查询,使用执行计划去判断查询是否正常运行,总是去测试你的查询看看是否他们运行在最佳状态下。...无需在执行存储过程和触发器的每个语句后向客户端发送 DONE_IN_PROC 消息。 46,MySQL查询可以启用高速查询缓存。这是提高数据库性能的有效Mysql优化方法之一。...47,EXPLAIN SELECT 查询用来跟踪查看效果  使用 EXPLAIN 关键字可以让你知道MySQL是如何处理你的SQL语句的。这可以帮你分析你的查询语句或是表结构的性能瓶颈。

1.9K20

借助profile优化MySQL查询语句

问题 上周客户反馈有个功能比较卡,经同事排查是因为一个SQL语句查询比较慢导致的: SELECT am.article_id, am.simhash FROM...都改成char(24),发现没什么效果,看来MySQL也不会那么傻。...这个语句命中的记录行数确实是比较多的(3.6万多),但是返回的两个字段都是业务需要的。一时没了主意,想了一些准备绕过这个问题的解决方案。...后来想起phpmyadmin是可以分析sql语句的性能(MySQL profile),分析结果如下: 显然,绝大部分时间都花在了sending data上,眼前一亮,肯定是返回的数据太多或者中间过程的数据量太多...优化MySQL查询语句,单靠explain是不够的,profile往往是更加有效的方法。

1.4K20

MySQL索引与SQL语句优化

1、前导模糊查询不能使用索引,   如name like ‘%静’ 2、Union、in、or可以命中索引,建议使用in 3、负条件查询不能使用索引,可以优化为in查询,   其中负条件有!...13、建立索引的列不能为null,使用not null约束及默认值 14、利用延迟关联或者子查询优化超多分页场景, MySQL并不是跳过offset行,而是取offset+N行,然后放弃前offset...18、Select语句务必指明字段名称 19、如果排序字段没有用到索引,就尽量少排序 20、尽量用union all 代替 union。   ...select id,name from product limit 866613, 20 使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。...优化的方法如下: 可以取前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。 比如此列中,上一页最大的id是866612。

1.6K10

如何实现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.5K20

mysql优化sql语句的方法

15.索引并不是越多越好,索引固然可以提高相应的 select 的效率,但同时也降低了 insert 及 update 的效率,因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑...1、为什么要进行mysql优化?...通过各种对数据库的优化方法,获取最高的查询和加载性能,达到查询性能的提高和加载性能的提高。 3、掌握优化的方式和途径 建表、索引、配置、SQL语句都需要优化 4、掌握建表和分表优化?...原本存储于一个表的数据分块存储到多个表上 5、掌握数据库的查询优化 ①关键字一般放在SELECT查询语句的前面,用于描述MySQL如何执行查询操作、以及MySQL成功返回结果集需要执行的行数。...5、掌握MySQL数据库的索引优化 6、掌握数据库的配置优化 7、掌握数据库的查询优化 一般来说,要保证数据库的效率,要做好以下四个方面的工作:数据库设计、sql语句优化、数据库参数配置、恰当的硬件资源和操作系统

1.2K20

MySQL中SQL语句优化路径

碰巧看到杨老师的这篇文章《第45期:一条 SQL 语句优化的基本思路》,为我们优化一些MySQL数据库的SQL语句提供了可借鉴的路径,值得参考和应用。 SQL语句优化是一个既熟悉又陌生的话题。...以MySQL为例,一条SQL语句从客户端发出到数据库端返回结果一般会经历几个阶段:词法解析、语法解析、语义解析、逻辑优化、物理优化、最终执行并返回结果。...InnoDB引擎(MySQL 5.7以及以前一些老旧版本可能会有非InnoDB引擎表),如果不是,转换表引擎为InnoDB。...因为MySQL从5.5版本开始,所有针对存储层的优化都是针对InnoDB 引擎的。 极个别表为临时表。查看临时表相关参数是否设置合理;或者说能否把临时表替换为磁盘表。...经过以上几个步骤,一般的语句基本上都能达到比较优化的结果。 虽然上面说的是MySQL数据库,但是一些理论上,其他的关系型数据库都是可以借鉴的。

2K10
领券