Heim  >  Artikel  >  Datenbank  >  mysql update in 报错解决

mysql update in 报错解决

WBOY
WBOYOriginal
2016-06-07 15:52:332582Durchsuche

在用到mysql update in的时候报错 update area set status='ON' where id in(select id from area where status='ON' and name like '%市辖%') [SQL]update area set status='ON' where id in(select id from area where status='ON' and name like '%市辖%'

在用到mysql  update in的时候报错

update area set status='ON' where id in(select id from area where status='ON' and name like '%市辖%')


[SQL]update area set status='ON' where id in(select id from area where status='ON' and name like '%市辖%')


[Err] 1093 - You can't specify target table 'area' for update in FROM clause



下面语句可以通过

update area a  inner join(select id from area where id in(select id from area where status='ON' and name like '%市辖%')) b on  a.id=b.id set a.status='OFF'

select * from area a inner join(select id from area where id in(select id from area where status='ON' and name like '%市辖%')) b on  a.id=b.id


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:高效的MySQL分页语句的效率Nächster Artikel:MYSQL导入数据到TXT