MySQL SQL UPDATE语句出现#1093错误解决办法
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-04 11:10:46 浏览: 评论:0
本文章来给各位同学介绍在MySQL SQL UPDATE语句出现#1093错误解决办法,有碰互此问题的朋友不防进入参考参考.
我使用了这样一个SQL,代码如下:
- UPDATE `student_quiz_answer` SET `article_id`= (SELECT qa.article_id, sqa.answer_id FROM student_quiz_answer sqa LEFT JOIN `quiz_answer` qa ON sqa.answer_id = qa.answer_id where qa.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 语句:
- UPDATE `student_quiz_answer` t1, (SELECT qa.article_id, sqa.answer_id FROM student_quiz_answer sqa LEFT JOIN `quiz_answer` qa ON sqa.answer_id = qa.answer_id where qa.article_id > 0) t2 SET t1.`article_id`= t2.article_id WHERE t1.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错误.
Tags: UPDATE语句 1093错误
相关文章
- ·mysql update根据A表更新B表的sql语句(2014-09-27)
- ·mysql SELECT FOR UPDATE 语句用法详解(2014-09-28)
- ·mysql update语句使用方法总结(2014-10-03)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)