V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
timepast
V2EX  ›  MySQL

关于 update table_1 set ... where table_1.id = (select table_1.id from table_1 where ...) 的问题

  •  
  •   timepast ·
    idyllim · 2014-05-29 11:40:11 +08:00 · 4822 次点击
    这是一个创建于 3838 天前的主题,其中的信息可能已经有所发展或是发生改变。
    如题的语句在mysql中报错:You can't specify target table table_1 for update in FROM clause

    解决办法是:
    UPDATE table_1 SET set...
    WHERE
    table_1.x = (
    SELECT pick.id FROM (SELECT tmp.id FROM table_1 tmp WHERE tmp.x = ? AND tmp.x = ?) pick )
    但是这个语句的性能是不是不如分步操作的性能呢?
    3 条回复    2014-05-29 16:07:07 +08:00
    Dwyanetalk
        1
    Dwyanetalk  
       2014-05-29 14:28:30 +08:00
    不明白这是要干什么?感觉在绕圈子……select后面的where直接当update的where不行吗?
    timepast
        2
    timepast  
    OP
       2014-05-29 15:34:02 +08:00
    @Dwyanetalk 报错
    lu18887
        3
    lu18887  
       2014-05-29 16:07:07 +08:00
    结合查询计划进行分析吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2503 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 15:45 · PVG 23:45 · LAX 07:45 · JFK 10:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.