MySQL SQL UPDATE语句出现#1093错误解决办法

小明SEO博客 小明SEO博客,新时代SEO博客

本文章来给各位同学介绍在MySQL SQL UPDATE语句出现#1093错误解决办法,有碰互此问题的朋友不防进入参考参考.

我使用了这样一个SQL,代码如下:

  1. UPDATE`student_quiz_answer`SET`article_id`=(SELECTqa.article_id,sqa.answer_idFROMstudent_quiz_answersqaLEFTJOIN`quiz_answer`qaONsqa.answer_id=qa.answer_idwhereqa.article_id>0)

问题来自MySQL更新Table某个字段时,如果 Update 值中存在自身Table 的 Select 就会遇到这个错误提示:

#1093 – You can’t specify target table ‘student_quiz_answer’ for update in FROM clause

但是SQL的 Update 值又必须根据当前Table的字段进行查询.

把 Update 值作为一个新 Table,比如 t2,本身 table 别名为 t1,条件子句就是 t1 和 t2 的关联值相等.

正确实现方法,需要建立一张中间表,中间表的内容和frjg表完全相同,之后进行修改frjg表,中间和frjg表之间存在“主外键关系”,并不存在这种关系,修改为这样一个 SQL 语句:

  1. UPDATE`student_quiz_answer`t1,(SELECTqa.article_id,sqa.answer_idFROMstudent_quiz_answersqaLEFTJOIN`quiz_answer`qaONsqa.answer_id=qa.answer_idwhereqa.article_id>0)t2SETt1.`article_id`=t2.article_idWHEREt1.answer_id=t2.answer_id--phpfensi.com

总结:1093错误为,但修改一个表的时候子查询不能是同一个表,解决办法,把子查询再套一层,变成原来表的孙子查询就可以了,例如:

insert into gg set id3= (select c.a+1 from (select max(id3) as a from gg) c) 这是对的

但是 insert into gg set id3= (select max(id3) as a from gg) 就会报1093错误.

相关广告
  • MySQL SQL UPDATE语句出现#1093错误解决办法 MySQL SQL UPDATE语句出现#1093错误解决办法 MySQL SQL UPDATE语句出现#1093错误解决办法
相关阅读

MySQL SQL UPDATE语句出现#1093错误解决办法

2019/10/10 17:35:19 | 谷歌SEO算法 | 搜索引擎