-- 存储过程创建库  分为两条语句删除和创建
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存储过程分库分表的更多相关文章

  1. MySQL订单分库分表多维度查询

    转自:http://blog.itpub.net/29254281/viewspace-2086198/ MySQL订单分库分表多维度查询  MySQL分库分表,一般只能按照一个维度进行查询. 以订单 ...

  2. MySQL+MyCat分库分表 读写分离配置

    一. MySQL+MyCat分库分表 1 MyCat简介 java编写的数据库中间件 Mycat运行环境需要JDK. Mycat是中间件.运行在代码应用和MySQL数据库之间的应用. 前身 : cor ...

  3. php面试专题---mysql数据库分库分表

    php面试专题---mysql数据库分库分表 一.总结 一句话总结: 通过数据切分技术将一个大的MySQLServer切分成多个小的MySQLServer,既攻克了写入性能瓶颈问题,同一时候也再一次提 ...

  4. MySQL之分库分表

    MySQL之分库分表(MyCAT实现)   分库分表介绍 随着微服务这种架构的兴起,我们应用从一个完整的大的应用,切分为很多可以独立提供服务的小应用.每个应用都有独立的数据库. 数据的切分分为两种: ...

  5. 使用ShardingSphere-JDBC完成Mysql的分库分表和读写分离

    1. 概述 老话说的好:选择比努力更重要,如果选错了道路,就很难成功. 言归正传,之前我们聊了使用 MyCat 实现Mysql的分库分表和读写分离,MyCat是服务端的代理,使用MyCat的好处显而易 ...

  6. mysql数据库分库分表shardingjdbc

    分库分表理解 分库分表应用于互联网的两个场景;大量数据和高并发,通常策略有两种:垂直分库,水平拆分 垂直拆分:是根据业务将一个库拆分为多个库,将一个表拆分为多个表,例如:将不常用的字段和经常访问的字段 ...

  7. Mysql 之分库分表方案

    Mysql分库分表方案 为什么要分表 当一张表的数据达到几千万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目的就在于此,减小数据库的负担,缩短查询时间. mysq ...

  8. mysql的分库分表

    1 什么是分库分表 这里讨论的情况是一台机器上对应一个数据库. 分库的对象是表,分表的对象是行.分库是说把属于同一个模块的相关性很高的表放在同一个数据库中.分表是说把同一个表的的行分成多个子表,把各个 ...

  9. 面试官:说说Mysql数据库分库分表,并且会有哪些问题?

    之前一篇文章已经谈到了数据库集群之主从集群也就是读写分离,也提到了读写分离其实只是分担了访问的压力,但是存储的压力没有解决. 存储的压力说白了就是随着系统的演化,需求的增加,可能表的数量会逐渐增多,比 ...

随机推荐

  1. ZOJ2975 伪数组压缩+组合数

    Kinds of Fuwas Time Limit: 2 Seconds      Memory Limit:65536 KB In the year 2008, the 29th Olympic G ...

  2. Jmeter连接mysql数据库

    1.下载 MySQL JDBC driver,并拷贝到jmeter的lib目录下. 2.创建JDBC Connection Configuration 需要填入的信息: Variable Name:M ...

  3. EasyUI Tree 树 ——实现多级别菜单的展示,以及与后台数据的交互

    一 要引入的js css库 <link type="text/css" href="css/base.css" rel="stylesheet& ...

  4. 【Windows 10 应用开发】使用x:Bind标记动态获得计算结果

    UWP 在传统(WPF)的Binding标记上引入了 Bind 标记,Bind 基于编译阶段生成,因而具有较高的性能.但是,你得注意,这个性能上的优化是免去了运行阶段动态绑定的开销,这是不包括数据源的 ...

  5. visual studio 2015 warning MSB3246

    在我们很高兴的按下 本地计算机运行 按钮,希望看到我们程序运行的时候,垃圾vs就告诉我们,你的程序出现了问题,问题就是: warning MSB3246: 解析的文件包含错误图像.无元数据或不可访问. ...

  6. Golang开发者常见的坑

    Golang开发者常见的坑 目录 [−] 初级 开大括号不能放在单独的一行 未使用的变量 未使用的Imports 简式的变量声明仅可以在函数内部使用 使用简式声明重复声明变量 偶然的变量隐藏Accid ...

  7. HTTPS和HTTP有什么区别?如何将HTTP转化成HTTPS

    不知道大家有没有注意到输入网址时的HTTP部分,在打开网站进行操作时有时候会自动跳转为HTTPS格式,这是为什么?HTTP与HTTPS到底有什么区别?如何将HTTP转化成HTTPS,针对这些问题,我们 ...

  8. phalcon——验证

    一个完整的使用实例:(验证模型数据) use Phalcon\Mvc\Model; use Phalcon\Mvc\Model\Validator\Email as EmailValidator; u ...

  9. Bootstrap的核心——栅格系统的使用

        前  言 絮叨絮叨 Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷. 而栅格系统是Bootstrap中的核心,正是因为栅格系统的 ...

  10. Ubuntu16.04卸载opencv2.4.9并安装opencv3.2.0+contrib

    本文为作者原创,转载请注明出处(http://www.cnblogs.com/mar-q/)by 负赑屃 需要用到opencv中的surf和sift算法,机器上只有opencv3.2,没有扩展包,于是 ...