有什么方法可以更新MySQL中所有字段的长度吗?我试过了:
ALTER TABLE mytable MODIFY * VARCHAR(150);
但没有快乐。有什么建议吗?
您可以使用information_schema
数据库中的信息为您生成查询。
如果您需要将表myTable
中的所有varchar(100)列更改为varchar(150),请使用查询:
SELECT CONCAT( 'ALTER TABLE `myTable`',
GROUP_CONCAT(
CONCAT( 'nMODIFY ', COLUMN_NAME, ' VARCHAR(150) ' ),
'' )
) AS query
FROM information_schema.COLUMNS
WHERE DATA_TYPE = 'varchar'
AND CHARACTER_MAXIMUM_LENGTH = 100
AND TABLE_SCHEMA = 'myDatabase'
GROUP BY TABLE_NAME
然后将输出复制/粘贴为另一个查询以完成实际工作。
您必须专门修改每一列。
ALTER TABLE mytable
MODIFY col_1 VARCHAR(150),
MODIFY col_2 VARCHAR(150),
MODIFY col_3 VARCHAR(150);
请注意,所有修改都可以在一次"传递"中完成,因此这比运行n个单独的ALTER TABLE
调用更高效。