我被指派创建一个 bash 脚本来检查AUTO_INCREMENT
列何时接近其限制。我认为最好的方法是获取“当前自动增量值”并与“支持的列的数据类型的最大值”进行比较(比如 255 tinyint
)。
我们的数据库中有大约 2Tb 的数据,我不想查询INFORMATION SCHEMA
表来获取数据,AUTO_INCREMENT
因为它需要太长时间。
因此我不能使用(SHOW TABLE STATUS LIKE 'table_name')
也不能(SELECT AUTO_INCREMENT FROM information_schema.tables)
因为这两个查询INFORMATION SCHEMA
表。
我被告知可能有一种解决方法可以在不访问信息模式表的情况下获取当前的 AUTO_INCREMENT,但我不知道如何。有任何想法吗?
这就是我获取数据类型的方式
DATA_TYPE="`$MYSQLCONNECT -D $DATABASE --batch -N -e "SELECT DATA_TYPE FROM
INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = '$DATABASE' AND TABLE_NAME='$TABLE' AND
EXTRA='auto_increment'"`"
这就是我获得该列可以处理的最大值的方式:
MAX_VALUE="`$MYSQLCONNECT -D $DATABASE --batch -N -e "SELECT ( CASE '$DATA_TYPE' WHEN 'tinyint'
THEN 255 WHEN 'smallint' THEN 65535 WHEN 'mediumint' THEN 16777215 WHEN 'int' THEN 4294967295
WHEN 'bigint' THEN 18446744073709551615 END >> IF(LOCATE('unsigned', COLUMN_TYPE) > 0, 0, 1) )
as MAX_VALUE FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = '$DATABASE' AND TABLE_NAME
= '$TABLE' AND EXTRA='auto_increment'"`"