如果我有以下表&数据允许我们使用sort_index
排序:MySQL的更新排序索引列到移动项目
CREATE TABLE `foo` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`bar_id` INT(11) DEFAULT NULL,
`sort_index` INT(11) DEFAULT NULL,
PRIMARY KEY (`id`)
);
INSERT INTO `foo` (`bar_id`, `sort_index`) VALUES
(1,1),(1,2),(1,3),(1,4),
(2,1),(2,2),(2,3),(2,4),(2,5);
我希望能够做到以下几点以最有效方式:
- 移动FOO条目到给定位置(由bar_id作用域)
- 确保
sort_index
始终为1索引,有没有间隙 - 您应该能够将项目移至开始和列表和规则#2仍应适用结束
- 应在查询全部完成,尽可能少的可能(因为台可能是非常大的循环在他们做个别
UPDATE
s的不理想)
- 确保
为了澄清什么,我试图做的,让我们假设该表是空的,所以我们有以下数据:
id | bar_id | sort_index
1 | 1 | 1
2 | 1 | 2
3 | 1 | 3
4 | 1 | 4
5 | 2 | 1
6 | 2 | 2
7 | 2 | 3
8 | 2 | 4
9 | 2 | 5
然后如果我们做以下动作
- 富1至sort_index 3
- FOO 7 sort_index 1个
- 富5 sort_index 5
我们应得的以下数据:
id | bar_id | sort_index
1 | 1 | 3
2 | 1 | 1
3 | 1 | 2
4 | 1 | 4
5 | 2 | 5
6 | 2 | 2
7 | 2 | 1
8 | 2 | 3
9 | 2 | 4
SELECT * FROM foo ORDER BY bar_id, sort_index;
给我们:
id | bar_id | sort_index
2 | 1 | 1
3 | 1 | 2
1 | 1 | 3
4 | 1 | 4
7 | 2 | 1
6 | 2 | 2
8 | 2 | 3
9 | 2 | 4
5 | 2 | 5
为了澄清你的问题:给定上面的插入,你希望在开始时插入另一个'bar_id' = 1的行,导致所有后续行的更新(列'sort_index') 'bar_id'是1的位置? – tangens 2009-10-17 08:56:55
总结您的要求,对于任何一组“bar_id”,sort_index必须从零开始,并加1,直到最大的sort_index数字。你想完全在MySQL中执行任何移动/添加/删除操作? – 2009-10-17 08:58:40