北京SEO

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

2019/10/10/17:35:19  阅读:4141  来源:谷歌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错误解决办法

相关阅读

热门评论

小明SEO博客 小明SEO博客

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

总篇数171

精选文章

RMAN中catalog和nocatalog区别介绍 小技巧:为Linux下的文件分配多个权限 zimbra8.5.1安装第三方签名ssl证书的步骤 解决mysql不能远程连接数据库方法 windows服务器mysql增量备份批处理数据库 mysql中slow query log慢日志查询分析 JavaScript跨域问题总结 Linux下负载均衡软件LVS配置(VS/DR)教程 mysql中权限参数说明 MYSQL(错误1053)无法正常启动

SEO最新算法