mysql 一個(gè)較特殊的問題:You can't specify target table 'wms_cabinet_form'
更新時(shí)間:2010年11月30日 21:31:34 作者:
mysql 一個(gè)較特殊的問題:You can't specify target table 'wms_cabinet_form' for update in F
今天在寫 mysql 遇到一個(gè)比較特殊的問題。
mysql 語句如下:
update wms_cabinet_form set cabf_enabled=0
where cabf_id in (
SELECT wms_cabinet_form.cabf_id FROM wms_cabinet_form
Inner Join wms_cabinet ON wms_cabinet_form.cabf_cab_id = wms_cabinet.cab_id
Inner Join wms_cabinet_row ON wms_cabinet.cab_row_id =wms_cabinet_row.row_id
where wms_cabinet_row.row_site_id=27 and wms_cabinet_form.cabf_enabled=1)
運(yùn)行時(shí)提出如下提示: You can't specify target table 'wms_cabinet_form' for update in FROM clause
運(yùn)行 in 里面的 select 字句:
SELECT wms_cabinet_form.cabf_id FROM wms_cabinet_form
Inner Join wms_cabinet ON wms_cabinet_form.cabf_cab_id = wms_cabinet.cab_id
Inner Join wms_cabinet_row ON wms_cabinet.cab_row_id =wms_cabinet_row.row_id
where wms_cabinet_row.row_site_id=27 and wms_cabinet_form.cabf_enabled=1
可以正確 select 正確結(jié)果。再把結(jié)果直接寫到 in 里面,改后語句如下:
update wms_cabinet_form set cabf_enabled=0 where cabf_id in ('113','114','115'),再運(yùn)行可以正確執(zhí)行更新。
到這一步開始想不明白,為什么用 select 子句運(yùn)行會出錯(cuò)呢?以前在 mssql 這種寫法是很常見的。
沒辦法了,唯有動用 baidu。找到兩條記錄。
原來原因是:mysql中不能這么用。 (等待mysql升級吧)。那串英文錯(cuò)誤提示就是說,不能先select出同一表中的某些值,
再update這個(gè)表(在同一語句中)。 也找到替代方案,重寫改寫了 sql 。
改寫后的 sql 如下所示,大家仔細(xì)區(qū)別一下。
update wms_cabinet_form set cabf_enabled=0 where cabf_id in (
SELECT a.cabf_id FROM (select tmp.* from wms_cabinet_form tmp) a
Inner Join wms_cabinet b ON a.cabf_cab_id = b.cab_id
Inner Join wms_cabinet_row c ON b.cab_row_id = c.row_id
where c.row_site_id=29 and a.cabf_enabled=1)
重點(diǎn)在 SELECT a.cabf_id FROM (select tmp.* from wms_cabinet_form tmp) a ,我 select tmp.* from wms_cabinet_form tmp 作為子集,
然后再 select a.cabf_id FROM 子集,這樣就不會 select 和 update 都是同一個(gè)表。致此問題得到完美解決。
mysql 語句如下:
update wms_cabinet_form set cabf_enabled=0
where cabf_id in (
SELECT wms_cabinet_form.cabf_id FROM wms_cabinet_form
Inner Join wms_cabinet ON wms_cabinet_form.cabf_cab_id = wms_cabinet.cab_id
Inner Join wms_cabinet_row ON wms_cabinet.cab_row_id =wms_cabinet_row.row_id
where wms_cabinet_row.row_site_id=27 and wms_cabinet_form.cabf_enabled=1)
運(yùn)行時(shí)提出如下提示: You can't specify target table 'wms_cabinet_form' for update in FROM clause
運(yùn)行 in 里面的 select 字句:
SELECT wms_cabinet_form.cabf_id FROM wms_cabinet_form
Inner Join wms_cabinet ON wms_cabinet_form.cabf_cab_id = wms_cabinet.cab_id
Inner Join wms_cabinet_row ON wms_cabinet.cab_row_id =wms_cabinet_row.row_id
where wms_cabinet_row.row_site_id=27 and wms_cabinet_form.cabf_enabled=1
可以正確 select 正確結(jié)果。再把結(jié)果直接寫到 in 里面,改后語句如下:
update wms_cabinet_form set cabf_enabled=0 where cabf_id in ('113','114','115'),再運(yùn)行可以正確執(zhí)行更新。
到這一步開始想不明白,為什么用 select 子句運(yùn)行會出錯(cuò)呢?以前在 mssql 這種寫法是很常見的。
沒辦法了,唯有動用 baidu。找到兩條記錄。
原來原因是:mysql中不能這么用。 (等待mysql升級吧)。那串英文錯(cuò)誤提示就是說,不能先select出同一表中的某些值,
再update這個(gè)表(在同一語句中)。 也找到替代方案,重寫改寫了 sql 。
改寫后的 sql 如下所示,大家仔細(xì)區(qū)別一下。
update wms_cabinet_form set cabf_enabled=0 where cabf_id in (
SELECT a.cabf_id FROM (select tmp.* from wms_cabinet_form tmp) a
Inner Join wms_cabinet b ON a.cabf_cab_id = b.cab_id
Inner Join wms_cabinet_row c ON b.cab_row_id = c.row_id
where c.row_site_id=29 and a.cabf_enabled=1)
重點(diǎn)在 SELECT a.cabf_id FROM (select tmp.* from wms_cabinet_form tmp) a ,我 select tmp.* from wms_cabinet_form tmp 作為子集,
然后再 select a.cabf_id FROM 子集,這樣就不會 select 和 update 都是同一個(gè)表。致此問題得到完美解決。
您可能感興趣的文章:
- oracle—SQL技巧之(二)WMSYS.WM_CONCAT函數(shù)實(shí)現(xiàn)多行記錄用逗號拼接在一起
- SQL語句練習(xí)實(shí)例之五 WMS系統(tǒng)中的關(guān)于LIFO或FIFO的問題分析
- woso.exe,wlso.exe,wmso.exe, woso.exe,ztso.exe 等木馬盜號病毒專殺工具
- iwms access與sql版的安裝與轉(zhuǎn)換
- Android自定義Toast之WindowManager
- Android利用WindowManager實(shí)現(xiàn)懸浮窗
- 深入理解Android中的Window和WindowManager
- Android利用WindowManager生成懸浮按鈕及懸浮菜單
- 在當(dāng)前Activity之上創(chuàng)建懸浮view之WindowManager懸浮窗效果
- Android中WindowManager與WMS的解析
相關(guān)文章
利用mysql事務(wù)特性實(shí)現(xiàn)并發(fā)安全的自增ID示例
項(xiàng)目中經(jīng)常會用到自增id,比如uid,下面為大家介紹下利用mysql事務(wù)特性實(shí)現(xiàn)并發(fā)安全的自增ID,感興趣的朋友可以參考下2013-11-11修改Innodb的數(shù)據(jù)頁大小以優(yōu)化MySQL的方法
這篇文章主要介紹了修改Innodb的數(shù)據(jù)頁大小以優(yōu)化MySQL的方法,Innodb是MySQL下一個(gè)頗具人氣的數(shù)據(jù)引擎,需要的朋友可以參考下2015-05-05將MySQL從MyISAM轉(zhuǎn)換成InnoDB錯(cuò)誤和解決辦法
原來自己用的是為了裝的, 所以在設(shè)置database usage(如下圖1)的時(shí)候按照discuz官方的建議,選的都是Non-Transactional Database Only(只支持MyISAM數(shù)據(jù)引擎的非事務(wù)數(shù)據(jù)庫),用MyISAM數(shù)據(jù)庫,還沒涉及到需要InnoDB,因此打算直接不加載INNODB引擎。2011-09-09mysql二進(jìn)制日志文件恢復(fù)數(shù)據(jù)庫
喜歡的在服務(wù)器或者數(shù)據(jù)庫上直接操作的兄弟們你值得收藏下!不然你就悲劇了。-----(當(dāng)然我也是在網(wǎng)上搜索的資料!不過自己測試通過了的!)2014-08-08MySQL模式 Strict Mode知識點(diǎn)詳解
在本篇文章里小編給各位整理的是一篇關(guān)于MySQL模式 Strict Mode知識點(diǎn)詳解內(nèi)容,需要的朋友們參考下。2020-03-03