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