MySQL:ID号自动递增的不一致

Posted

技术标签:

【中文标题】MySQL:ID号自动递增的不一致【英文标题】:MySQL: the inconsistency of auto increment in id numbers 【发布时间】:2011-06-13 17:01:58 【问题描述】:

我想知道您是否遇到过自动增量的 id 编号没有按正确顺序排列当您单击 phpMyAdmin 上的“浏览”按钮时 - 只有我吗?我在 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 ;

【问题讨论】:

【参考方案1】:

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

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

【讨论】:

asc 在技术上不是必需的,但 +1 表示没有默认顺序。 @Omar:ASC 是明确易读的,如果你肯定想要升序,那么没有理由省略它。【参考方案2】:

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

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

除非您指定,否则您应该假设实际顺序是随机的。实际上,它是任意的而不是随机的,但表格内容的更改很容易改变顺序。

【讨论】:

【参考方案3】:

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

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

【讨论】:

感谢您的回复。我刚刚在上面发布了我的一个表结构。谢谢! PK 是主键。我从您的创建声明中看到您正在使用 MISAM 作为存储引擎。该引擎的默认选择顺序是插入记录的顺序。所以这就是为什么你得到你得到的结果。确保通过主键对选择进行排序的唯一方法是在选择查询中使用 ORDER BY。由于您只对 phpmyadmin 的默认行为感兴趣,因此您只能通过更改 phpmyadmin 的代码来完成这些操作。您可以尝试将存储引擎更改为默认使用 PK 排序的 InnoDB 选择

以上是关于MySQL:ID号自动递增的不一致的主要内容,如果未能解决你的问题,请参考以下文章

MySQL读取的记录和我想象的不一致——事物隔离级别和MVCC

MySQL读取的记录和我想象的不一致——事物隔离级别和MVCC

MySQL读取的记录和我想象的不一致——事物隔离级别和MVCC

Mysql数据库显示时间与应用程序获取到的不一致的问题

Mysql数据库显示时间与应用程序获取到的不一致的问题

Mysql数据库显示时间与应用程序获取到的不一致的问题