mysql 一個較特殊的問題:You can't specify target table 'wms_cabinet_form'
更新時間:2010年11月30日 21:31:34 作者:
mysql 一個較特殊的問題:You can't specify target table 'wms_cabinet_form' for update in F
今天在寫 mysql 遇到一個比較特殊的問題。
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)
運行時提出如下提示: You can't specify target table 'wms_cabinet_form' for update in FROM clause
運行 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'),再運行可以正確執(zhí)行更新。
到這一步開始想不明白,為什么用 select 子句運行會出錯呢?以前在 mssql 這種寫法是很常見的。
沒辦法了,唯有動用 baidu。找到兩條記錄。
原來原因是:mysql中不能這么用。 (等待mysql升級吧)。那串英文錯誤提示就是說,不能先select出同一表中的某些值,
再update這個表(在同一語句中)。 也找到替代方案,重寫改寫了 sql 。
改寫后的 sql 如下所示,大家仔細區(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)
重點在 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 都是同一個表。致此問題得到完美解決。
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)
運行時提出如下提示: You can't specify target table 'wms_cabinet_form' for update in FROM clause
運行 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'),再運行可以正確執(zhí)行更新。
到這一步開始想不明白,為什么用 select 子句運行會出錯呢?以前在 mssql 這種寫法是很常見的。
沒辦法了,唯有動用 baidu。找到兩條記錄。
原來原因是:mysql中不能這么用。 (等待mysql升級吧)。那串英文錯誤提示就是說,不能先select出同一表中的某些值,
再update這個表(在同一語句中)。 也找到替代方案,重寫改寫了 sql 。
改寫后的 sql 如下所示,大家仔細區(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)
重點在 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 都是同一個表。致此問題得到完美解決。
您可能感興趣的文章:
- oracle—SQL技巧之(二)WMSYS.WM_CONCAT函數(shù)實現(xiàn)多行記錄用逗號拼接在一起
- SQL語句練習(xí)實例之五 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實現(xiàn)懸浮窗
- 深入理解Android中的Window和WindowManager
- Android利用WindowManager生成懸浮按鈕及懸浮菜單
- 在當(dāng)前Activity之上創(chuàng)建懸浮view之WindowManager懸浮窗效果
- Android中WindowManager與WMS的解析
相關(guān)文章
利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID示例
項目中經(jīng)常會用到自增id,比如uid,下面為大家介紹下利用mysql事務(wù)特性實現(xiàn)并發(fā)安全的自增ID,感興趣的朋友可以參考下2013-11-11修改Innodb的數(shù)據(jù)頁大小以優(yōu)化MySQL的方法
這篇文章主要介紹了修改Innodb的數(shù)據(jù)頁大小以優(yōu)化MySQL的方法,Innodb是MySQL下一個頗具人氣的數(shù)據(jù)引擎,需要的朋友可以參考下2015-05-05將MySQL從MyISAM轉(zhuǎn)換成InnoDB錯誤和解決辦法
原來自己用的是為了裝的, 所以在設(shè)置database usage(如下圖1)的時候按照discuz官方的建議,選的都是Non-Transactional Database Only(只支持MyISAM數(shù)據(jù)引擎的非事務(wù)數(shù)據(jù)庫),用MyISAM數(shù)據(jù)庫,還沒涉及到需要InnoDB,因此打算直接不加載INNODB引擎。2011-09-09mysql二進制日志文件恢復(fù)數(shù)據(jù)庫
喜歡的在服務(wù)器或者數(shù)據(jù)庫上直接操作的兄弟們你值得收藏下!不然你就悲劇了。-----(當(dāng)然我也是在網(wǎng)上搜索的資料!不過自己測試通過了的!)2014-08-08