1

我有一个包含应用程序设置的表,其中包含以下列:idkeyvalue

id列是自动递增的,但截至目前,我不使用它,也没有任何外键约束。我正在填充设置并希望对其进行重组,以便它们按字母顺序排列,因为我没有以这种方式放置设置,但按字母顺序重新排序将有助于将相关设置组合在一起。

例如,如果我有以下设置:

ID     KEY             VALUE
======================================
1      App.Name        MyApplication
2      Text.Title      Title of My App
3      App.Version     0.1

我希望将所有 App.* 设置按顺序组合在一起,而不必每次都执行 ORDER BY。无论如何,这就是解释。我尝试了以下方法,但似乎并没有改变顺序:

CREATE TABLE mydb.Settings2 LIKE mydb.Settings;
INSERT INTO mydb.Settings2 SELECT `key`,`value` FROM mydb.Settings ORDER BY `key` ASC;
DROP TABLE mydb.Settings;
RENAME TABLE mydb.Settings2 TO mydb.Settings;

这将按照建议复制表格,但不会重组数据。我在这里想念什么?

4

2 回答 2

3

重新排序表格的简单方法是使用ALTER TABLE table ORDER BY column ASC. 您尝试的查询看起来应该有效,但我知道 ALTER TABLE 查询有效;我经常使用它。

注意:重新排序表中的数据仅在 MyISAM 表中有效且有意义。InnoDB 始终以 PRIMARY KEY 顺序存储数据,因此无法重新排列。

于 2013-02-12T19:06:34.243 回答
2

决定做出这样的回答。

正如我在对最初答案的评论中所说,为了获得长期效果,您需要重新创建设置表,并将键列作为主键。因为正如 G-Nugget 所说的那样,“InnoDB 总是以 PRIMARY KEY 顺序存储数据”。

你可以这样做

CREATE TABLE settings2
    (`id` int NULL, `key` varchar(64), `value` varchar(64), PRIMARY KEY(`key`));
INSERT INTO settings2 
SELECT id, `key`, `value` 
  FROM settings;
DROP TABLE settings;
RENAME TABLE settings2 TO settings;

这样,您在插入新记录后就可以完好无损地获得订单。

如果您不需要表中的初始id列,那么现在是放弃settings它的好时机。

这是工作的sqlfiddle

免责声明:我个人ORDER BY无论如何都会使用

于 2013-02-12T20:04:24.553 回答