Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 一次检索数据库中所有表的最大主键值_Mysql_Database - Fatal编程技术网

Mysql 一次检索数据库中所有表的最大主键值

Mysql 一次检索数据库中所有表的最大主键值,mysql,database,Mysql,Database,我需要做的是一次检索数据库中所有表的最大主键?也就是说,如果我执行以下两个查询,我的结果将类似: SHOW TABLES FROM DATABASE_NAME SELECT MAX(PRIMARY_KEY) AS maxId FROM TABLE 就是 (first column = TableName , second column = MAX(PK) Of that table) 如果我做错了什么,请原谅。我只是不想写80个查询,因为我的数据库有80个表。如果(且仅当)主键是自动递增变

我需要做的是一次检索数据库中所有表的最大主键?也就是说,如果我执行以下两个查询,我的结果将类似:

SHOW TABLES FROM DATABASE_NAME

SELECT MAX(PRIMARY_KEY) AS maxId FROM TABLE
就是

(first column = TableName , second column = MAX(PK) Of that table)
如果我做错了什么,请原谅。我只是不想写80个查询,因为我的数据库有80个表。

如果(且仅当)主键是
自动递增
变量,则可以执行以下操作:

SELECT TABLE_NAME, AUTO_INCREMENT
FROM   information_schema.TABLES
WHERE  TABLE_SCHEMA = 'mydb'

在选择检索该信息的方法以及如何处理该信息时,请注意以下情况:

自动增量值存储在内存中,因此服务器重新启动后,自动增量值将重置为:

SELECT MAX(ai_col) FROM table_name FOR UPDATE;
如果数据库缺少FK,例如,删除了引用其他表的某些行,则这可能会造成问题。您最终将重用相同的id


请参阅:

这听起来像是固定的经典案例。你到底想做什么?@Perception我正在从Windows迁移到Linux,所以我需要这个。从一个操作系统迁移到另一个操作系统与主键到底有什么关系?你可能在这里重新发明轮子,你能给我们更多的细节吗,因为如果它看起来是这样的话-还有其他方法。我们现在已经停止了我们的数据库,所以它是用于增量恢复的。我仍然不明白为什么你不使用复制或简单的mysqldump..让我们说我的数据库名是“谢谢”比where子句中的未知列“谢谢”@FawadGhafoor您必须将表名放在引号中-这是一个字符串。@FawadGhafoor抱歉,我混淆了“表名”/“数据库名”-最后一个参数是数据库名,查询将为每个表返回一行。@FawadGhafoor因此在
选择
;-)中请求
自动增量-1