文章详情页
mysql 怎么做到update只更新一行数据?
浏览:161日期:2022-06-19 11:21:53
问题描述
UPDATE quan.hexiao_code SET sort_code=’LKUHFS’ WHERE sort_code=’SAMQLF’;
这句话的where部分有两条记录,我只想修改其中一条,该怎么写?
问题解答
回答1:UPDATE quan.hexiao_code SET sort_code=’LKUHFS’ WHERE sort_code=’SAMQLF’ limit 1;
回答2:我不知道楼主为什么会有这样的问题,在数据库当中每一条数据不应该都是独立的一条吗,有它自己的特征才对。所以当你WHERE sort_code=’SAMQLF’的时候很明显的意思就是更新所有匹配的数据。你如果只是更新一条,那么更新的是哪一条?是不是应该有它的特征才对,所以你应该把这个特征加上。如果你就是那么任性的要随机更新匹配的一条,我的方案就是随机查出sort_code=’SAMQLF’的一条记录的ID,用ID来更新这条记录。
刚刚看到了 @shuhai 的回答,感谢他让我知道了还有这样的语法,学艺不精- - |||用UPDATE LIMIT 1确实能解决楼主的问题。不过我还是推荐楼主应该有明确的,比如只更新匹配的并且ID最大的一条UPDATE quan.hexiao_code SET sort_code=’LKUHFS’ WHERE sort_code=’SAMQLF’ ORDER BY id DESC LIMIT 1
相关文章:
1. python 多进程 或者 多线程下如何高效的同步数据?2. mysql - 要取出数据库中按某字段排序后的前10,20,30条数据要怎么做?3. css - 如何让子元素不受父元素overflow的影响4. windows-7 - win7下使用cmder,如何设置vim的tab为4个空格?5. word-wrap该如何使用?6. javascript - CSS图片轮播显示问题7. javascript - 关于js高级程序中的问题8. python - 怎么进行服务器性能分析9. MySQL的SELECT...FOR UPDATE究竟起什么作用10. thinkPHP5中获取数据库数据后默认选中下拉框的值,传递到后台消失不见。有图有代码,希望有人帮忙
排行榜

网公网安备