关于MySql update语句不能用子查询的解决办法

关于MySql update语句不能用子查询的解决办法

  • 使用MySql数据库语法操作update时,第一时间想到的是一下写法:

复制代码
  UPDATE purchase_request_detail SET convert_to_voucher_id=2, convert_to_voucher_type='inventory-voucher' 
  WHERE detail_id IN (select detail_id from purchase_request_detail where request_id=1 and item_id=1)
  • 但是这个时候就会报错:

  • You can't specify target table 'xxx' for update in FROM

  • MySql的update的一些特点:

  • update 时,更新的表不能在set和where中用于子查询;

  • update 时,可以对多个表进行更新(Sql Server不行);

  • 如:

  • update table_a A,table_b B set A.B_ID=B.ID ,B.A_ID=A.ID;

  • 所以MySql update是不允许使用子查询的,正确写法是:

复制代码
  UPDATE purchase_request_detail AS table_1 
  INNER JOIN (select detail_id from purchase_request_detail where request_id=1 and item_id=1) 
  AS table_2 SET convert_to_voucher_id=2, convert_to_voucher_type='inventory-voucher'  WHERE table_1.d

-----------------------------------------------------------------------------------

offer突击训练营简介:

1:针对不知道怎么面试,面试没有信心的小伙伴,我们会给你一个offer保障。

2:我们会监督你15-20天内把面试体系技术点掌握至少7成,这样足够你去找到满意的工作了。

3:我们是面向面试学习指导,不会带你们去写代码,会把项目真实开发的迭代过程和技术细节如何实现业务功能都详细教清楚,你能在面试中流畅表达清楚就行了,项目经验你不用担心(技术老师提供的真实项目经验肯定拿的出手),自己学和别人带着系统学,效率完全不一样。

详情请点击这里offer突击训练营,给你一个offer的保障,求职跳槽的看过来!

相关推荐
Irene19913 分钟前
SQL示例:外键约束是关系型数据库中用于建立两个表之间链接的一种规则
mysql
dadaobusi7 分钟前
PCIe的ATS和PRS
java·网络·数据库
汽车仪器仪表相关领域9 分钟前
HORIBA MEXA-584L 全功能汽车排放废气分析仪:便携精准排放检测 + 多参数同步测量 + 国六 / 欧 7 合规适配,汽车检测与调校的黄金标准
服务器·数据库·人工智能·功能测试·汽车·压力测试·可用性测试
南境十里·墨染春水15 分钟前
线程池学习(二)线程池理解
java·jvm·学习
ZGi.ai16 分钟前
私有化大模型接入企业系统:SSO+权限+API网关完整方案
java·开发语言·大模型·私有化部署·sso·企业架构
Han_han91917 分钟前
集合进阶(Map集合):
java
吴声子夜歌19 分钟前
Java——文件和目录操作
java·文件·目录
qq_3660862220 分钟前
SQL 中 OR 与 UNION ALL选择指南
数据库·sql
吴声子夜歌23 分钟前
Java——随机
java·random·随机
正在走向自律26 分钟前
时序数据库技术内幕:从大数据存储模型看工业级时序数据库的设计与落地
大数据·数据库·时序数据库·工业物联网存储·tsfile 存储引擎·大数据时序技术·物联网数据治理