zoukankan      html  css  js  c++  java
  • Mysql中You can't specify target table for update in FROM clause错误的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中)。

    将select出的结果再通过中间表select一遍,这样就规避了错误。注意,这个问题只出现于mysql,mssql和oracle不会出现此问题。

    mysql中You can't specify target table for update in FROM clause错误的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中)。

    later:

     But:

     Subquery returns more than 1 row表示子查询返回了多行数据

     

    开始:

    delete from tbl where id in 
    (
            select max(id) from tbl a where EXISTS
            (
                select 1 from tbl b where a.tac=b.tac group by tac HAVING count(1)>1
            )
            group by tac
    )

    right:

    delete from tbl where id in 
    (
        select a.id from 
        (
            select max(id) id from tbl a where EXISTS
            (
                select 1 from tbl b where a.tac=b.tac group by tac HAVING count(1)>1
            )
            group by tac
        ) a
    )

  • 相关阅读:
    项目进度管理-PMBook 第六章
    项目范围管理-PMBook 第五章
    PMBook 中的开发生命周期
    项目整合管理-PMBook 第四章
    PMP 学习心得
    二维码的来源和生活应用
    package main 红色波浪线
    JS中监听事件的几种方法
    PEP8规范
    RestFul API 规范
  • 原文地址:https://www.cnblogs.com/datang6777/p/6762608.html
Copyright © 2011-2022 走看看