如何使用另一个表中的 MAX 值重置 MySQL 自动递增?


您可以使用预处理语句来使用另一个表中的 MAX 值重置 MySQL 自动递增。

以下是语法:

set @anyVariableName1=(select MAX(yourColumnName) from yourTableName1);
SET @anyVariableName2 = CONCAT('ALTER TABLE yourTableName2
AUTO_INCREMENT=', @anyVariableName1);
PREPARE yourStatementName FROM @anyVariableName2;
execute yourStatementName;

以上语法将使用另一个表中的最大值重置 MySQL auto_increment。为了理解以上语法,让我们创建两个表。第一个表将包含记录,第二个表将使用第一个表中的最大值并将其用于自动递增属性。

创建表的查询如下:

mysql> create table FirstTableMaxValue
   -> (
   -> MaxNumber int
   -> );
Query OK, 0 rows affected (0.64 sec)

使用 insert 命令从表中插入记录。查询如下:

mysql> insert into FirstTableMaxValue values(100);
Query OK, 1 row affected (0.15 sec)

mysql> insert into FirstTableMaxValue values(1000);
Query OK, 1 row affected (0.19 sec)

mysql> insert into FirstTableMaxValue values(2000);
Query OK, 1 row affected (0.12 sec)

mysql> insert into FirstTableMaxValue values(90);
Query OK, 1 row affected (0.15 sec)

mysql> insert into FirstTableMaxValue values(2500);
Query OK, 1 row affected (0.17 sec)

mysql> insert into FirstTableMaxValue values(2300);
Query OK, 1 row affected (0.12 sec)

使用 select 语句显示表中的所有记录。

查询如下:

mysql> select *from FirstTableMaxValue;

输出

+-----------+
| MaxNumber |
+-----------+
|       100 |
|      1000 |
|      2000 |
|        90 |
|      2500 |
|      2300 |
+-----------+
6 rows in set (0.05 sec)

现在您可以创建一个第二个表。创建第二个表的查询如下:

mysql> create table AutoIncrementWithMaxValueFromTable
   -> (
   -> ProductId int not null auto_increment,
   -> Primary key(ProductId)
   -> );
Query OK, 0 rows affected (1.01 sec)

在这里,我将包含一个语句,该语句将获取第一个表中的最大值并将最大值设置为第二个表的自动递增属性。查询如下:

mysql> set @v=(select MAX(MaxNumber) from FirstTableMaxValue);
Query OK, 0 rows affected (0.00 sec)

mysql> SET @Value2 = CONCAT('ALTER TABLE AutoIncrementWithMaxValueFromTable
AUTO_INCREMENT=', @v);
Query OK, 0 rows affected (0.00 sec)

mysql> PREPARE myStatement FROM @value2;
Query OK, 0 rows affected (0.29 sec)
Statement prepared

mysql> execute myStatement;
Query OK, 0 rows affected (0.38 sec)
Records: 0 Duplicates: 0 Warnings: 0

现在我们已将第一个表中的最大值 2500 添加到第二个表中。现在您可以向表中插入记录,这些记录将从 2500、2501 等开始。

向第二个表中插入记录的查询如下:

mysql> insert into AutoIncrementWithMaxValueFromTable values();
Query OK, 1 row affected (0.24 sec)

mysql> insert into AutoIncrementWithMaxValueFromTable values();
Query OK, 1 row affected (0.10 sec)

使用 select 命令检查表中的所有记录。查询如下:

mysql> select *from AutoIncrementWithMaxValueFromTable;

输出

+-----------+
| ProductId |
+-----------+
|      2500 |
|      2501 |
+-----------+
2 rows in set (0.00 sec)

更新于: 2019-07-30

1K+ 浏览量

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告