有没有办法可以更新MySQL中所有字段的长度?我试过了:
ALTER TABLE mytable MODIFY * VARCHAR(150);
但没有快乐。有什么建议吗?
答案 0 :(得分:3)
您可以使用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
然后将输出复制/粘贴为另一个查询以执行实际作业。
答案 1 :(得分:0)
您必须专门修改每一列。
ALTER TABLE mytable
MODIFY col_1 VARCHAR(150),
MODIFY col_2 VARCHAR(150),
MODIFY col_3 VARCHAR(150);
请注意,所有修改都可以在一个“通过”中完成,因此这比运行n个ALTER TABLE
个调用更有效。