MYSQL通过存储过程实现批量建表
时间:2022-05-03
本文章向大家介绍MYSQL通过存储过程实现批量建表,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
适用于分表比较多的情况,如何批量创建,可通过存储过程实现。
存储过程批量执行只是临时使用,不建议业务使用存储过程,有些存储过程封装SQL较多,导致性能下降,不容易排查。
创建一个存储过程:红色为表结构,蓝色为表名及表数量,从0开始到255
MySQL root@[test]> delimiter //
MySQL root@[test]> create procedure sp_create_tab()
begin
set @str = " (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
`bak0` varchar(128) DEFAULT NULL COMMENT '备用',
`bak1` varchar(128) DEFAULT NULL COMMENT '备用',
`bak2` varchar(128) DEFAULT NULL COMMENT '备用',
`bak3` varchar(128) DEFAULT NULL COMMENT '备用',
`bak4` varchar(128) DEFAULT NULL COMMENT '备用',
`bak5` varchar(128) DEFAULT NULL COMMENT '备用',
`bak6` varchar(128) DEFAULT NULL COMMENT '备用',
`bak7` varchar(128) DEFAULT NULL COMMENT '备用',
`bak8` varchar(128) DEFAULT NULL COMMENT '备用',
`bak9` varchar(128) DEFAULT NULL COMMENT '备用',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL COMMENT '修改时间',
PRIMARY KEY (`id`),
KEY `bak0` (`bak0`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='表'";
set @j = 0;
while @j < 256 do
set @table = concat('table_name_',@j);
set @sql_t = concat("CREATE TABLE ",@table,@str);
prepare sql_t from @sql_t;
execute sql_t;
set @j = @j + 1;
end while;
end
//
Query OK, 0 rows affected (0.00 sec)
MySQL root@[test]> delimiter ;
MySQL root@[test]> call sp_create_tab;
MySQL root@[test]> drop procedure sp_create_tab;
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- 不用数组求多个数的最小值
- 小程序 Tip | 文档、环境、开发工具界面与特性
- 大佬的思路就是不一样,这是我见过最简洁又清晰的SSM框架整合
- SQL Server重置自增的值为0
- 被经理邀请去“爬山”,只是因为我写错了一条SQL语句?
- Maven环境配置-必会
- Centos7中Docker安装RabbitMQ
- 又陷入知识盲区了,面试被问Redis事务,我差点脸都“绿”了
- Mybatis中#{}与${}的区别
- POI合并单元格
- Centos7.x安装Docker
- 实在是妙啊!Java中强软虚弱引用,居然还能这样去操作
- 数据库连接池引起的FullGC问题,看我如何一步步排查、分析、解决
- Swift 数组dropFirst方法
- Swift 类方法和实例方法