3

我想知道您是否遇到过这样的情况:当您单击 phpMyAdmin 上的浏览​​按钮时,自动递增的 id 编号没有按正确的顺序排列- 只有我一个人吗?我在 db 表中设置错误?

例如,当您将一系列数据插入到一个表中并且您也删除了其中一些数据时,因此当您在 phpMyAdmin 上查看该表时,这些数据应该以这样的顺序出现,

id

2
24
28
296
300

但在我的大多数表格中,它们并没有出现在订单中,而是出现在这样的地方,

id

24
300    
2
296    
28

如下图所示,

替代文字

我们可以做点什么让 ID 以正确的顺序出现吗?

编辑1:

我想你们中的大多数人都误解了我在这里突袭的问题。我的意思是当您单击 phpMyAdmin 上的浏览​​器按钮以列出表中的所有数据时 - 而不是当您使用 SQL 查询列出输出时使用order by.

是否有意义?

替代文字

编辑2:

这是我的表结构之一——它是否可以帮助您查看其中的问题?

CREATE TABLE IF NOT EXISTS `root_pages` (
  `pg_id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `pg_url` varchar(255) DEFAULT NULL,
  `pg_title` varchar(255) DEFAULT NULL,
  `pg_subtitle` varchar(255) DEFAULT NULL,
  `pg_description` text,
  `pg_introduction` text,
  `pg_content_1` text,
  `pg_content_2` text,
  `pg_content_3` text,
  `pg_content_4` text,
  `pg_order` varchar(255) DEFAULT NULL,
  `pg_hide` varchar(255) DEFAULT '0',
  `pg_highlight` varchar(255) DEFAULT '0',
  `pg_important` varchar(255) DEFAULT '0',
  `pg_parent` varchar(255) DEFAULT '0',
  `parent_id` varchar(255) DEFAULT NULL,
  `pg_cat_id` varchar(255) DEFAULT NULL COMMENT 'page category id',
  `ps_cat_id` varchar(255) DEFAULT NULL COMMENT 'post category id',
  `tmp_id` varchar(255) DEFAULT NULL COMMENT 'template id',
  `pg_backdate` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `pg_created` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `pg_updated` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`pg_id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
4

3 回答 3

7

您可以随意订购输出:ORDER BY id ASC.

表中的记录没有固有的顺序。

于 2011-01-22T15:21:49.077 回答
2

如果您希望它们按 ID 排序,那么您必须order by在选择时使用子句。

使用 SQL,返回的集合select是无序的,除非您指定您希望它们的顺序。

您应该假设实际订单将是随机的,除非您指定它。实际上,它是任意的而不是随机的,但是对表格内容的更改可以很容易地更改顺序。

于 2011-01-22T15:23:20.853 回答
1

不确定这是否适用于您,但您的 PK 是 INT 类型吗?如果它是某种 VARCHAR 或 TEXT,它可以像您展示的示例一样排序。你确定那个专栏实际上是你的PK吗?发布表的 SHOW CREATE TABLE 输出,它可能会变得更清晰。

以及您使用的是哪个存储引擎。如果我没记错的话,选择的默认顺序是 MISAM 的插入顺序和 InnoDB 的 PK。这也取决于您的 MySql 版本。为了确保在所有情况下您都应该在您的选择语句中使用 ORDER BY。

于 2011-01-22T16:02:51.160 回答