mysql提取建表语句_获取MySQL中某个数据库下所有表建表语句的DDL

本脚本可以获取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, ',')

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值