Mysql 自定义函数和存储过程自动批量生产数据脚本

随机时间函数:

复制代码
DELIMITER $ 
DROP FUNCTION IF EXISTS rand_time;
CREATE FUNCTION rand_time(startTime datetime, endTime datetime) RETURNS datetime
BEGIN
    DECLARE ms int;
		DECLARE resultTime datetime;
		SET ms = DATEDIFF(endTime,startTime);
		SET resultTime = DATE_ADD(startTime, interval Floor(ms*rand()*5/8) day);
		RETURN resultTime;
END $
DELIMITER;

随机数函数:

复制代码
DELIMITER $ 
DROP FUNCTION if EXISTS rand_num;
CREATE FUNCTION rand_num() RETURNS INT(5)
BEGIN
    DECLARE i INT DEFAULT 0;
    SET i = FLOOR(100+RAND()*10);
    RETURN i;
END $
DELIMITER;

随机字符串函数

复制代码
DELIMITER $ 
DROP FUNCTION if EXISTS rand_string;
CREATE FUNCTION rand_string(n INT) RETURNS VARCHAR(255)
BEGIN
    DECLARE chars_str VARCHAR(100) DEFAULT 'abcdefghijklmlopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    DECLARE return_str VARCHAR(255) DEFAULT '';
    DECLARE i INT DEFAULT 0;
    WHILE i < n DO
    SET return_str = CONCAT(return_str,SUBSTRING(chars_str,FLOOR(1+RAND()*52),1));
    SET i = i+1;
    END WHILE;
    RETURN return_str;
END $
DELIMITER;
实战案例:

表结构:

复制代码
-- 创建两个表:员工表和部门表
-- 部门表,存在则进行删除
drop table if EXISTS dep;
create table dep(
    id int unsigned primary key auto_increment,
    depno mediumint unsigned not null default 0,
    depname varchar(20) not null default "",
    memo varchar(200) not null default ""
);

-- 员工表,存在则进行删除
drop table if EXISTS emp;
create table emp(
    id int unsigned primary key auto_increment,
    empno mediumint unsigned not null default 0,
    empname varchar(20) not null default "",
    job varchar(9) not null default "",
    mgr mediumint unsigned not null default 0,
    hiredate datetime not null,
    sal decimal(7,2) not null,
    comn decimal(7,2) not null,
    depno mediumint unsigned not null default 0
);

注意说明
-- mediumint是MySQL数据库中的一种整型,比INT小,比SMALLINT大,
-- 取值范围为:-8388608到8388607,无符号的范围是0到16777215。
-- 中等大小的整数,一位大小为3个字节。

编写存储过程,模拟 6000000的员工数据

复制代码
-- 编写存储过程,模拟 100W 的员工数据。
-- 建立存储过程:往emp表中插入数据
 DELIMITER $
 drop PROCEDURE if EXISTS insert_emp;
 CREATE PROCEDURE insert_emp(IN START INT(10),IN max_num INT(10))
 BEGIN
     DECLARE i INT DEFAULT 0;
     /*set autocommit =0 把autocommit设置成0,把默认提交关闭*/
     SET autocommit = 0;
     REPEAT
     SET i = i + 1;
     INSERT INTO emp(empno,empname,job,mgr,hiredate,sal,comn,depno) VALUES ((START+i),rand_string(6),'SALEMAN',0001,now(),2000,400,rand_num());
     UNTIL i = max_num
     END REPEAT;
     COMMIT;
 END $
 DELIMITER;
 
-- 插入600W条数据,时间有点久,耐心等待
 call insert_emp(0,6000000);

-- 查询部门员工表
select * from emp LIMIT 1,10;

编写存储过程,模拟 120 的部门数据

复制代码
-- 编写存储过程,模拟 120 的部门数据
-- 建立存储过程:往dep表中插入数据
 DELIMITER $
 drop PROCEDURE if EXISTS insert_dept;
 CREATE PROCEDURE insert_dept(IN START INT(10),IN max_num INT(10))
 BEGIN
     DECLARE i INT DEFAULT 0;
     SET autocommit = 0;
     REPEAT
     SET i = i+1;
     INSERT  INTO dep( depno,depname,memo) VALUES((START+i),rand_string(10),rand_string(8));
     UNTIL i = max_num
     END REPEAT;
     COMMIT;
 END $
 DELIMITER;
 
-- 插入120条数据
 call insert_dept(1,120);

-- 查询部门员工表
select * from dep;

备份表结构和数据:

复制代码
备份表结构和数据
方法一:SELECT * INTO ims_stock_quantity_balance_bak FROM ims_stock_quantity_balance; 
报错Undeclared variable可以使用方法二
方法二:create table ims_stock_quantity_balance_bak (select * from ims_stock_quantity_balance);

从一个表中复制所有的列插入到另一个已存在的表中
INSERT INTO ims_stock_quantity_balance_bak SELECT * FROM ims_stock_quantity_balance;

总结:
select into from 和 insert into select都是用来复制表,两者的主要区别为: 
  select into from 要求目标表不存在,因为在插入时会自动创建。
  insert into select from 要求目标表存在。
相关推荐
poemyang2 小时前
十年大厂员工终明白:MySQL性能优化的尽头,是对B+树的极致理解
mysql·pagecache·顺序i/o·局部性原理·b tree·b+ tree
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任4 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
安卓开发者5 小时前
Android RxJava 组合操作符实战:优雅处理多数据源
android·rxjava
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼5 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jerry说前后端5 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
alexhilton6 小时前
深入浅出着色器:极坐标系与炫酷环形进度条
android·kotlin·android jetpack
xiep14383335107 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
Java小白程序员8 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring