dongzhao4036 2017-10-31 06:47
浏览 93
已采纳

为什么更新查询条件失败

i have sql table as follow

id      position
------------
1       2
2       1
3       3

Now i wants to perform action that return result as follow

 id     position
    ------------
    1       1
    2       2
    3       3

So how can i do ?

  • 写回答

2条回答 默认 最新

  • doukao5073 2017-10-31 07:30
    关注

    Use two variables to store the positioncolumn values of ids having 1 and 2. Then use a CASE expression to update the table accordingly.

    Query

    set @a := (select `position` from `your_table_name` where id = 1);
    set @b := (select `position` from `your_table_name` where id = 2);
    
    update `your_table_name`
    set `position` = (
        case `id` when 1 then @b else @a end
    )
    where `id` < 3;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型
  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条
  • ¥15 Python报错怎么解决
  • ¥15 simulink如何调用DLL文件