SHOW TABLE NEXT_ROW_ID
SHOW TABLE NEXT_ROW_ID 用于显示表中某些特殊列的详细信息,包括:
_tidb_rowid,由 TiDB 自动管理并支持的隐藏行 ID 列。- 用户创建的
AUTO_INCREMENT列。 - 用户创建的
AUTO_RANDOM列。 - 用户创建的
SEQUENCE。
语法
- ShowTableNextRowIDStmt
ShowTableNextRowIDStmt ::=
"SHOW" "TABLE" (SchemaName ".")? TableName "NEXT_ROW_ID"
示例
对于新创建的表,由于尚未分配 Row ID,NEXT_GLOBAL_ROW_ID 为 1。
CREATE TABLE t(a int);
Query OK, 0 rows affected (0.06 sec)
SHOW TABLE t NEXT_ROW_ID;
+---------+------------+-------------+--------------------+
| DB_NAME | TABLE_NAME | COLUMN_NAME | NEXT_GLOBAL_ROW_ID |
+---------+------------+-------------+--------------------+
| test | t | _tidb_rowid | 1 |
+---------+------------+-------------+--------------------+
1 row in set (0.00 sec)
表中已写入数据。插入数据的 TiDB 服务器会一次性分配并缓存 30000 个 ID。因此,NEXT_GLOBAL_ROW_ID 现在为 30001。ID 的数量由 AUTO_ID_CACHE 控制。
INSERT INTO t VALUES (), (), ();
Query OK, 3 rows affected (0.02 sec)
Records: 3 Duplicates: 0 Warnings: 0
SHOW TABLE t NEXT_ROW_ID;
+---------+------------+-------------+--------------------+
| DB_NAME | TABLE_NAME | COLUMN_NAME | NEXT_GLOBAL_ROW_ID |
+---------+------------+-------------+--------------------+
| test | t | _tidb_rowid | 30001 |
+---------+------------+-------------+--------------------+
1 row in set (0.00 sec)
MySQL 兼容性
此语句是 TiDB 对 MySQL 语法的扩展。