weijiajia11 2023-03-20 13:01 采纳率: 0%
浏览 51

sql 新增一条数据后按价格高低修改排序字段数据

有4个字段 id 物品 价格 排序
怎么写个语句 insert into 一条数据后,紧接着做个语句按价格大小修改排序名次

  • 写回答

3条回答 默认 最新

  • 以山河作礼。 新星计划导师 2023-03-20 13:10
    关注

    假设表名为 goods,可以这样写:

    -- 插入一条数据
    INSERT INTO goods (id, item, price, sort) VALUES (5, '手机', 1999, 0);
    
    -- 按价格从高到低更新排序字段
    UPDATE goods SET sort = (SELECT COUNT(*) FROM goods WHERE price >= g.price) WHERE id = 5;
    

    上面的更新语句中,使用了子查询来计算当前价格高于等于该行数据价格的行数,然后将该数值赋给该行数据的排序字段。这样就可以实现按价格从高到低排序的效果。

    评论

报告相同问题?

问题事件

  • 创建了问题 3月20日