文章详情页
mysql - 使用update语句同时更新两个表的问题?
浏览:195日期:2022-06-16 10:31:11
问题描述
先贴sql: update class ,student set class.class_id = ’2011’,student.class_id = class.class_id where class_name = ’一班’;
我的需求是将class表中一班的id修改为2011,然后将student表中所有的学生的班级id都更新。但是上面的sql的执行结果是先执行student.class_id = class.class_id ,然后再执行class.class_id = ’2011’
一开始我以为是赋值语句顺序的问题,于是我把两个赋值语句调换了顺序,发现效果还是不变。。。为什么呢?正确的写法是什么呢?
问题解答
回答1:如果我没记错的话,标准里规定更新顺序是从左到右,变量优先。但是标准规定是一回事,DBMS 有没有严格遵守标准又是另一回事,不同的 DBMS 可能出来结果不一样。只有查了你用的 DBMS 的文档才能知道到底是什么情况。
保险的做法就是写两条 update,其实效率应该是非常接近的。
回答2:update class ,student set class.class_id = ’2011’,student.class_id = class.class_id where `class`.class_name = ’一班’ && `student`.class_name= ’一班’
上一条:mysql - 求纠正一个sql语句下一条:MySQL 书籍推荐
相关文章:
1. 如何解决docker宿主机无法访问容器中的服务?2. java - xml 传输数据如何处理更好3. javascript - h5上的手机号默认没有识别4. python - 类 对象 函数后面的参数问题,勉强看懂但是要自己写出来就感觉很困难5. javascript - 想让图片上那个块,在增加块的宽度的时候向右边移动,而不是向左边移动。需要怎么解决?6. mysql - 要取出数据库中按某字段排序后的前10,20,30条数据要怎么做?7. 网页爬虫 - Python爬虫入门知识8. 求大神帮我看看是哪里写错了 感谢细心解答9. Python Selenium WebDriver如何刷新当前页面10. 用tp5框架写sql语句
排行榜

网公网安备