我有这张桌子:
id ref data
1 111 data1
2 111 data2
3 111 data3
4 111 data4
5 222 data1
6 222 data2
7 222 data3
8 333 data1
9 333 data2
我想插入一个新字段,例如 order ,其中对于每个ref,我将设置一个新月值。所以输出应该是:
id ref data order
1 111 data1 1
2 111 data2 2
3 111 data3 3
4 111 data4 4
5 222 data1 1
6 222 data2 2
7 222 data3 3
8 333 data1 1
9 333 data2 2
我可以通过简单的查询来完成吗?
修改
上面的例子只是一个例子。这是我在数据库上真正的表:
CREATE TABLE `items` (
`id` int(11) unsigned NOT NULL auto_increment,
`trackid` varchar(255) NOT NULL,
`side` varchar(255) NOT NULL,
`side_pos` char(2) NOT NULL default '#',
`pos` int(11) NOT NULL,
`hh` char(2) NOT NULL,
`mm` char(2) NOT NULL,
`ss` char(2) NOT NULL,
`atl` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=20229 DEFAULT CHARSET=utf8
答案 0 :(得分:6)
MySQL不支持分析(IE:ROW_NUMBER),这是您用于输出的输出。使用:
SELECT x.id, x.ref, x.data, x.rank AS `order`
FROM (SELECT t.id, t.ref, t.data
CASE
WHEN @ref = t.ref THEN @rownum := @rownum + 1
ELSE @rownum := 1
END AS rank,
@ref := t.ref
FROM YOUR_TABLE t
JOIN (SELECT @rownum := NULL, @ref := -1) r
ORDER BY t.id, t.ref, t.data) x
通常,这需要单独的语句来声明@rownum和@ref变量,但是如果像你在示例中看到的那样定义了MySQL,那么MySQL可以让你逃脱它。
如果ref
值不匹配,CASE语句会将@rownum值重置为1。否则,@rownum递增1。与递增的@rownum值相关联的列由ORDER BY
子句确定。
答案 1 :(得分:1)
我相信如果您创建一个看起来像(ref,order)的主键,其中order是auto_increment,您可以让数据库自动为您创建。
http://mysqldump.azundris.com/archives/5-AUTO_INCREMENT-Trivia.html