假设我有一张桌子如下:

name VARCHAR(50) PRIMARY KEY NOT NULL
ordernum TINYINT UNSIGNED NOT NULL

也就是说我有三排。
something     - 1
somethingelse - 2
somethingmore - 3

如果我想插入另一个名为something1的条目,并将ordernum设为2,那么如何对ordernum为2或更大的所有行重新排序?即somethingelse变成ordernum为3,somethingmore变成ordernum为4?
我听说你可以通过FIELD()来做,但我不确定具体怎么做。
如果不可能,可以用PHP来做吗?

最佳答案

在您的示例中:

UPDATE `table` SET `ordernum` = `ordernum` + 1 WHERE `ordernum` >= 2
INSERT INTO `table` (`name`, `ordernum`) VALUES ('something1', 2)

08-07 08:37