首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL insert or update sql

MySQL 一条 sql 实现数据保存变更 insert or update ,如果没有执行insert,有就update 需要 有主键 PRIMARY 或 唯一索引 UNIQUE MySQL...中的INSERT … ON DUPLICATE KEY UPDATE语句,该语句是基于唯一索引或主键使用 ON DUPLICATE KEY UPDATE后面可以放多个字段,用英文逗号分割。...使用ON DUPLICATE KEY UPDATE,最终如果插入了一个新行,则受影响的行数是1,如果修改了已存在的一行数据,则受影响的行数是2,如果值不变,则受影响行数是0。...INSERT… ON DUPLICATE KEY UPDATE on a table with more than one UNIQUE KEY is unsafe 翻译:使用BINLOG_FORMAT...插入……对于具有多个唯一密钥的表的重复密钥更新是不安全的 相关博客:https://blog.csdn.net/rick_zyl/article/details/79024612 mysql 有就更新

2.7K20

MySQL 案例:Update 死锁详解

用户针对这个死锁的问题,提出了疑问:数据更新的并不是同一行,使用的也是不同的索引,为什么会发生死锁?...死锁的两个语句如下: UPDATE tbl_deadlock SET col1 = 1, col2 = 1, update_time = 1603685523 WHERE (id1 = 6247476)...AND (id2 = 74354) UPDATE tbl_deadlock SET col1 = 1, col2 = 1, update_time = 1603685523 WHERE (id1 =...MySQL 的锁机制天然具备这个条件。 请求与保持条件:资源请求被阻塞时,已持有的资源不会被释放。 MySQL 不触发死锁回滚,且未进入 lockwait_timeout 的时候,具备这个条件。...用户提出的疑问:使用的也是不同的索引,为什么会发送死锁?实际上二级索引上的记录锁,最终也会加到主键上。

14.4K174

Mysql Insert Or Update语法实例

有的时候会需要写一段insert的sql,如果主键存在,则update;如果主键不存在,则insert。Mysql中提供了这样的用法:ON DUPLICATE KEY UPDATE。...,它的意思是先执行前面的Insert,如果主键重复,则执行后面的UPDATE INSERT INTO test VALUES (1,'b4','c4') ON DUPLICATE KEY UPDATE...b=VALUES(b),c=VALUES(c); 可以把上面的SQL简单的理解为: select count(1) from test where a=1; if count(1) > 0 UPDATE...test SET b='xxx',c='xxx' WHERE a=1; 执行完,可以看到有两行收到影响(至于为什么两行收到影响,就得研究底层的实现了,可以参考官方文档): 1 queries executed..., 1 success, 0 errors, 0 warnings 查询:INSERT INTO test VALUES (1,'b4','c4') ON DUPLICATE KEY UPDATE b

1.9K70

Mysql INSERT ON DUPLICATE KEY UPDATE

ON DUPLICATE KEY UPDATEMySQL insert的一种扩展。...注意事项 当操作执行成功之后,affected-rows的值可能为0,1,2 返回值为1时:表里没有重复的记录,进行的是新增插入操作 返回值为2时:表里有重复的记录,但是其余值不一致,进行了update...操作 返回值为0时:表里有重复的记录,并且其余值完全一致,无需update操作 当然,以上成立的条件是CLIENT_FOUND_ROWS没有被设置过。...ON DUPLICATE KEY UPDATE强烈不推荐对拥有多个唯一索引(unique key)的表使用,除非你非常清醒地知道你在干什么会有什么样的后果。...引用资料 https://mariadb.com/kb/en/library/insert-on-duplicate-key-update/ https://dev.mysql.com/doc/refman

4.6K30

MySQL这样写UPDATE语句,劝退

来自:ju.outofmemory.cn/entry/336774 最近好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新...看起来,语法是完全没有问题,翻了翻MySQL官方文档的update语法: 看到assignment_list的格式是以逗号分隔的col_name=value列表,一下子豁然开朗,开发同学想要的多字段更新语句应该这样写...小结 : 在一条UPDATE语句中,如果要更新多个字段,字段间不能使用“AND”,而应该用逗号分隔。...后记 : 后面等有空的时候,又回过头来看了一下,为什么使用“AND”分隔的时候,会出现owner_code=0的奇怪结果?...因此,这个逻辑表达式的结果为 false , false在MySQL中等价于0!

3.9K40

MySQL这样写UPDATE语句,劝退

# 起因 最近,好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面update一条记录,语法都正确的,但记录并没有被更新… # 结论 小结:在一条UPDATE语句中,如果要更新多个字段...分析 看起来,语法是完全没有问题,翻了翻MySQL官方文档的update语法: 看到assignment_list的格式是以逗号分隔的col_name=value列表,一下子豁然开朗,开发同学想要的多字段更新语句应该这样写...小结:在一条UPDATE语句中,如果要更新多个字段,字段间不能使用“AND”,而应该用逗号分隔。...后记:后面等有空的时候,又回过头来看了一下,为什么使用“AND”分隔的时候,会出现owner_code=0的奇怪结果?...因此,这个逻辑表达式的结果为false,false在MySQL中等价于0!

3.1K20

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券