mysql存储过程分库分表
-- 存储过程创建库 分为两条语句删除和创建
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS createDBN $$
CREATE PROCEDURE createDBN(IN n INT,IN dbName VARCHAR(100),IN dropSql VARCHAR(255),IN createSql VARCHAR(255))
BEGIN
DECLARE i INT DEFAULT 0;
WHILE i<n DO
SET @tempName = CONCAT(dbName,CONVERT(i,CHAR(10)));
SET @dropTempSql = REPLACE(dropSql,'${tbTempName}',@tempName);
SET @dropTempSql2 = @dropTempSql;
PREPARE dropSTMT FROM @dropTempSql2;
EXECUTE dropSTMT;
DEALLOCATE PREPARE dropSTMT;
SET @createTempSql = REPLACE(createSql,'${tbTempName}',@tempName);
SET @createTempSql2 = @createTempSql;
PREPARE createSTMT FROM @createTempSql2;
EXECUTE createSTMT;
DEALLOCATE PREPARE createSTMT;
SET i=i+1;
END WHILE;
END $$
SET @dropSql = "DROP DATABASE IF EXISTS ${tbTempName};";
SET @creSql = "CREATE database ${tbTempName} character set=utf8;";
CALL createDBN(5,'tl',@dropSql,@creSql);
-- 存储过程 批量删除数据库
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS delDBN $$
CREATE PROCEDURE delDBN(IN dbName VARCHAR(50),IN startValue INT,IN endValue INT)
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE tempName VARCHAR(50);
SET i = startValue;
WHILE i<endValue DO
SET tempName=CONCAT(dbName,CONVERT(i,CHAR(10)));
SET @exeSql = CONCAT('drop database if exists ',tempName);
PREPARE exeSTMT FROM @exeSql;
EXECUTE exeSTMT;
DEALLOCATE PREPARE exeSTMT;
SET i=i+1;
END WHILE;
END $$
CALL delDBN('tl',0,5);
-- 存储过程 批量创建数据库
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS createDBN2 $$
CREATE PROCEDURE createDBN2(IN n INT,IN dbName VARCHAR(100))
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE tempName VARCHAR(50);
WHILE i<n DO
SET tempName = CONCAT(dbName,CAST(i AS CHAR(10)));
SET @exeDropSql = CONCAT('drop database if exists ',tempName);
SET @exeCreSql = CONCAT('create database ',tempName,' character set=utf8');
-- 删除
PREPARE exeDropSTMT FROM @exeDropSql;
EXECUTE exeDropSTMT;
DEALLOCATE PREPARE exeDropSTMT;
-- 创建
PREPARE exeCreSTMT FROM @exeCreSql;
EXECUTE exeCreSTMT;
DEALLOCATE PREPARE exeCreSTMT;
SET i=i+1;
END WHILE;
END $$
CALL createDBN2(5,'tl');
-- 存储过程 批量创建表
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS createTabN $$
CREATE PROCEDURE createTabN(IN dbN INT,IN tabN INT,IN dbName VARCHAR(50),IN tabName VARCHAR(50),IN creTabSql VARCHAR(1000))
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE j INT DEFAULT 0;
DECLARE tempName VARCHAR(100);
WHILE i<dbN DO
WHILE j<tabN DO
SET tempName = CONCAT(dbName,CONVERT(i,CHAR(10)),'.',tabName,CAST(j AS CHAR(10)));
SET @dropTabSql = CONCAT('drop table if exists ',tempName);
SET @exeSql = REPLACE(creTabSql,'${fullTempName}',tempName);
-- 删除表
PREPARE dropSTMT FROM @dropTabSql;
EXECUTE dropSTMT;
DEALLOCATE PREPARE dropSTMT;
-- 创建表
PREPARE exeSTMT FROM @exeSql;
EXECUTE exeSTMT;
DEALLOCATE PREPARE exeSTMT;
SET j=j+1;
END WHILE;
SET i=i+1;
SET j=0;
END WHILE;
END $$
SET @tsql="
create table ${fullTempName}(
id int not null primary key auto_increment,
lname varchar(10)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;
";
CALL createTabN(5,10,'tl','ll',@tsql);
-- 存储过程 批量删除表
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS delTabN $$
CREATE PROCEDURE delTabN(IN dbN INT,IN tabN INT,IN dbName VARCHAR(50),IN tabName VARCHAR(50))
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE j INT DEFAULT 0;
WHILE i<dbN DO
WHILE j<tabN DO
SET @tempName=CONCAT(dbName,CONVERT(i,CHAR(10)),'.',tabName,CAST(j AS CHAR(10)));
SET @dropSql=CONCAT('drop table if exists ',@tempName);
PREPARE dropSTMT FROM @dropSql;
EXECUTE dropSTMT;
DEALLOCATE PREPARE dropSTMT;
SET j=j+1;
END WHILE;
SET j=0;
SET i=i+1;
END WHILE;
END $$
CALL delTabN(5,10,'tl','ll');
-- 存储过程 批量创建库 创建表
DELIMITER $$
USE myplan $$
DROP PROCEDURE IF EXISTS creDBAndTabN $$
CREATE PROCEDURE creDBAndTabN(IN dbN INT,IN tabN INT,IN dbName VARCHAR(50),IN tabName VARCHAR(50),IN tabSql VARCHAR(500))
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE j INT DEFAULT 0;
WHILE i<dbN DO
SET @tempDBName = CONCAT(dbName,CAST(i AS CHAR(10)));
SET @dropDBSql = CONCAT('drop database if exists ',@tempDBName);
SET @creDBSql = CONCAT('create database ',@tempDBName,' character set=utf8');
-- 删除库
PREPARE dropDBSTMT FROM @dropDBSql;
EXECUTE dropDBSTMT;
DEALLOCATE PREPARE dropDBSTMT;
-- 创建库
PREPARE creDBSTMT FROM @creDBSql;
EXECUTE creDBSTMT;
DEALLOCATE PREPARE creDBSTMT;
-- 创建表
WHILE j<tabN DO
SET @tempTabName = CONCAT(dbName,CAST(i AS CHAR(10)),'.',tabName,CAST(j AS CHAR(10)));
SET @dropTabSql = CONCAT('drop table if exists ',@tempTabName);
SET @creTabSql = REPLACE(tabSql,'${fullTabName}',@tempTabName);
-- 删除表
PREPARE dropTabSTMT FROM @dropTabSql;
EXECUTE dropTabSTMT;
DEALLOCATE PREPARE dropTabSTMT;
-- 创建表
PREPARE creTabSTMT FROM @creTabSql;
EXECUTE creTabSTMT;
DEALLOCATE PREPARE creTabSTMT;
SET j=j+1;
END WHILE;
SET i=i+1;
SET j=0;
END WHILE;
END $$
SET @tsql="
create table ${fullTabName}(
id int not null primary key auto_increment,
lname varchar(10)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;
";
CALL creDBAndTabN(5,10,'tl','ll',@tsql);
mysql存储过程分库分表的更多相关文章
- MySQL订单分库分表多维度查询
转自:http://blog.itpub.net/29254281/viewspace-2086198/ MySQL订单分库分表多维度查询 MySQL分库分表,一般只能按照一个维度进行查询. 以订单 ...
- MySQL+MyCat分库分表 读写分离配置
一. MySQL+MyCat分库分表 1 MyCat简介 java编写的数据库中间件 Mycat运行环境需要JDK. Mycat是中间件.运行在代码应用和MySQL数据库之间的应用. 前身 : cor ...
- php面试专题---mysql数据库分库分表
php面试专题---mysql数据库分库分表 一.总结 一句话总结: 通过数据切分技术将一个大的MySQLServer切分成多个小的MySQLServer,既攻克了写入性能瓶颈问题,同一时候也再一次提 ...
- MySQL之分库分表
MySQL之分库分表(MyCAT实现) 分库分表介绍 随着微服务这种架构的兴起,我们应用从一个完整的大的应用,切分为很多可以独立提供服务的小应用.每个应用都有独立的数据库. 数据的切分分为两种: ...
- 使用ShardingSphere-JDBC完成Mysql的分库分表和读写分离
1. 概述 老话说的好:选择比努力更重要,如果选错了道路,就很难成功. 言归正传,之前我们聊了使用 MyCat 实现Mysql的分库分表和读写分离,MyCat是服务端的代理,使用MyCat的好处显而易 ...
- mysql数据库分库分表shardingjdbc
分库分表理解 分库分表应用于互联网的两个场景;大量数据和高并发,通常策略有两种:垂直分库,水平拆分 垂直拆分:是根据业务将一个库拆分为多个库,将一个表拆分为多个表,例如:将不常用的字段和经常访问的字段 ...
- Mysql 之分库分表方案
Mysql分库分表方案 为什么要分表 当一张表的数据达到几千万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目的就在于此,减小数据库的负担,缩短查询时间. mysq ...
- mysql的分库分表
1 什么是分库分表 这里讨论的情况是一台机器上对应一个数据库. 分库的对象是表,分表的对象是行.分库是说把属于同一个模块的相关性很高的表放在同一个数据库中.分表是说把同一个表的的行分成多个子表,把各个 ...
- 面试官:说说Mysql数据库分库分表,并且会有哪些问题?
之前一篇文章已经谈到了数据库集群之主从集群也就是读写分离,也提到了读写分离其实只是分担了访问的压力,但是存储的压力没有解决. 存储的压力说白了就是随着系统的演化,需求的增加,可能表的数量会逐渐增多,比 ...
随机推荐
- EXISTS/NOT EXISTS CASE WHEN等使用方法
--简单判断用法 WHERE EXISTS (SELECT * FROM cpay..System_Setting) --可以替换count ) FROM cpay..System_Setting U ...
- git gc -- 压缩历史信息
格式: git gc [选项] <path> 选项 git commit -a 提交所有改动的文件(a -- all) NOTE: XX 举例 压缩历史消息 git ...
- 【转】Python-__builtin__与__builtins__的区别与关系(超详细,经典)
在学习Python时,很多人会问到__builtin__.__builtins__和builtins之间有什么关系.百度或Google一下,有很 多答案,但是这些答案要么不准确,要么只说了一点点,并不 ...
- [Gitlab运维系列]Gitlab 403 forbidden 并发引起IP被封
问题 带着团队使用Git,使用的是自搭建的Gitlab.但今天打开页面的时候显示的是空白页面,上面还有一次文本Forbidden. 原因 Gitlab使用rack_attack做了并发访问的限制. 解 ...
- Mybatis,Spring,SpringMVC框架面试题
Mybatis测试 1, Mybatis的核心是( sqlsessionfactory ) 2, 使用Mybatis持久化框架进行数据查询需要返回的一个实体类的集合, 在<sel ...
- 浅谈script标签中的async和defer
script标签用于加载脚本与执行脚本,在前端开发中可以说是非常重要的标签了.直接使用script脚本的话,html会按照顺序来加载并执行脚本,在脚本加载&执行的过程中,会阻塞后续的DOM渲染 ...
- 张高兴的 Windows 10 IoT 开发笔记:HC-SR04 超声波测距模块
HC-SR04 采用 IO 触发测距.下面介绍一下其在 Windows 10 IoT Core 环境下的用法. 项目运行在 Raspberry Pi 2/3 上,使用 C# 进行编码. 1. 准备 H ...
- 解题笔记-洛谷-P1010 幂次方
0 题面 题目描述 任何一个正整数都可以用2的幂次方表示.例如 137=2^7+2^3+2^0 同时约定方次用括号来表示,即a^b 可表示为a(b). 由此可知,137可表示为: 2(7)+2(3)+ ...
- substance在java swing中使用注意事项
package org.dgw.uidemo; import java.awt.EventQueue; import javax.swing.JFrame; import javax.swing.UI ...
- Noip2016组合数(数论)
题目描述 组合数表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们可以给出计算 ...