大海话语 2022-02-11 10:34 采纳率: 87.9%
浏览 92
已结题

将当前的Mysql表中最大id值,更新为其它字段的值

我想将最大 值的id 更新 为当前表中其它的字段,这个sql语句 报错了。
不知道该 怎么修改哈。好像 oracle中不会出错呢..

 update comment_global set comment_target_id = (
            SELECT max(id) FROM comment_global
        )

  • 写回答

6条回答 默认 最新

  • cy子见 2022-02-11 11:19
    关注

    首先借用以下楼上的 

    UPDATE comment_global 
    SET comment_target_id = (select id from (
        SELECT max(id) as id FROM comment_global
    ) as c)
     
    

    其次你是不是没有条件限制
    comment_target_id 的值全部改成id的值吗?
    还是说id是条件
    comment_target_id 的值改成id 的值

    UPDATE comment_global 
    SET comment_target_id =(SELECT id FROM (
        SELECT MAX(id) AS id FROM comment_global
    ) AS c)
    WHERE id=
    (SELECT id FROM (
        SELECT MAX(id) AS id FROM comment_global
    ) AS c)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 2月19日
  • 已采纳回答 2月11日
  • 创建了问题 2月11日