mysql 为什么不能在同一个表上查询和更新?

来源:互联网 发布:淘宝电脑描述图片尺寸 编辑:程序博客网 时间:2024/04/30 12:30

mysql 为什么不能在同一个表上查询和更新?


案例

情况1:

update table set x = (select y from table where id =1)
error 1093: you cant specify target table test for update in from clause

情况2:
通常采用的解决方案
update table set x = select * from (select y from table where id =1) t


原因的猜想

我们都知道,mysql在from子句中遇到子查询时,先执行子查询并将结果放到一个临时表中,我们通常称它为“派生表”;临时表是没有索引、无法加锁的。

仔细观察情况1和情况2,差别就在于情况2将结果集放入临时表中;

基于差异和上述理论,我猜到的一种原因是,update时,会锁表,此时不能再select。所以第一个情况会报错。

如果将结果集包装一层,其实就是放入临时表,临时表不会上锁,所以,可以正常work。


反思

这个问题,是我在看《高性能mysql(第三版)》P232页,“同一个表上查询和更新”上想到的,虽然我知道结论,却不知道为什么,搜了很多资料,发现没人问到这个问题,高性能mysql(第三版)》也是简单的说了一下,所以只能通过推理和猜测来假设可能。困扰了1天多,想通后,那种身心通畅的感觉真是倍爽!


4 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 玻璃碗放进微波炉打不开怎么办 乐扣微波炉加热后打不开怎么办 美的微波炉盖子打不开怎么办 美的微波炉门都打不开了怎么办 饭煮好了有异味怎么办 一正常吃饭就胖怎么办 高铁盒饭没15的怎么办 上火车前票丢了怎么办 减肥期吃了汉堡怎么办 寿司店鳗鱼有刺怎么办 吃泡面胃难受该怎么办 吃上火的东西脸上长痘痘怎么办 减肥期间吃撑了怎么办 喝了变质的牛奶怎么办 绿豆糕吃多了会怎么办 小孩抓米饭烫了手怎么办 减肥不来月经了怎么办 吃了馊了的米饭怎么办 饭在冰箱里硬了怎么办 剩米饭反潮了怎么办 吃馊米饭中毒后怎么办? 蒸熟的米饭发黄怎么办 孕妇肉类吃的少怎么办 大米饭坏了吃了怎么办 米饭煮糊了锅怎么办 减肥吃了猪肉脯怎么办 吃了硬米饭胃痛怎么办 宝宝吃了硬物怎么办 米饭卡在喉咙里了怎么办 喉咙里卡了米饭怎么办 孕妇吃了坏鹅蛋怎么办 1岁大宝宝长短腿怎么办 行测中的判断推理怎么办 塑料盖子玻璃罐头瓶子打不开怎么办 猪肉烫火锅吃怎么办料 自制腊肠放干了怎么办 孕妇吃了4块腊肉怎么办 衣服沾了火锅味怎么办 皮包上有火锅味怎么办 芝士年糕裂开了怎么办 制作牛肉酱咸了怎么办