本脚本可以获取MySQL中某个数据库下所有表建表语句的DDL
注意:本脚本需在MySQL8.0以上版本运行
注意:本脚本不获取VIEW创建语句
注意:本脚本没有处理主键,外键等约束
注意:本脚本只处理非分区表,分区表请自己改写脚本
注意:如果你做数据迁移,想把MySQL数据库迁移到其他数据库,自己改写脚本
WITH tab AS
(SELECT table_name FROM information_schema.TABLES WHERE table_schema = '数据库名' and table_type='BASE TABLE')
SELECT CASE
WHEN id = -1 THEN
concat('create table ', table_name)
WHEN id = 0 THEN
'('
WHEN id = 1 AND max_id = 1 THEN
concat(' ', column_name, ' ', column_type)
WHEN id = 1 AND max_id <> 1 THEN
concat(' ', column_name, ' ', column_type, ',')
WHEN id >= 1 AND id < max_id THEN
concat(' ', column_name, ' ', column_type, ',')