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

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

假设表名为 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;

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

参考GPT和自己的思路:

可以使用如下的 SQL 语句来实现:

-- 插入一条数据
INSERT INTO table_name (id, item, price, sort)
VALUES (1, 'item_name', 100, 0);
 
-- 修改 sort 字段
UPDATE table_name SET sort = (
    SELECT COUNT(*) FROM table_name t
    WHERE t.price > table_name.price
) WHERE id = 1;

以上 SQL 语句会先插入一条数据,然后使用一个子查询来获取比当前物品价格高的数据数量,并将其作为新的排序名次赋值给该数据的 sort 字段(其中 id = 1 表示刚刚插入的数据的唯一标识)。注意,如果价格相同,则排序名次相同。

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^