mysql使用存储过程和函数创建数据

一、创建库表

CREATE DATABASE liujiangtao;#创建库名
USE liujiangtao;
CREATE TABLE `student_info`(#创建学生表
`id` INT(11) NOT NULL AUTO_INCREMENT,#自增
`student_id` INT NOT NULL,
`name` VARCHAR(20) DEFAULT NULL,
`course_id` INT NOT NULL,
`class_id` INT(11) DEFAULT NULL,
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,#以现在时间戳为日期时间
PRIMARY KEY(`id`)#主键
)ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

CREATE TABLE `course`(
`id` INT(11) NOT NULL AUTO_INCREMENT,
`course_id` INT NOT NULL,
`course_name` VARCHAR(40) DEFAULT NULL,
PRIMARY KEY(`id`)

)ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

二、创建要使用的函数

#在创建函数之前先要让变量log_bin_trust_function_creators=1,否则存储函数无法创建
SELECT @@log_bin_trust_function_creators variable;
SET GLOBAL log_bin_trust_function_creators=1;

#函数1:创建随机数据数据必需的存储函数
DELIMITER //#这是为了可以不被MySQL分号影响执行
CREATE FUNCTION rand_string(n INT)#输入的数据,在调用call时填入相对应的类型
 RETURNS VARCHAR(255)#函数都有返回值,这里是返回值的类型
BEGIN#函数体开始,前三行不需要分号;
  DECLARE chars_str VARCHAR(100) DEFAULT 'abcdefghigkmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
  DECLARE return_str VARCHAR(255) DEFAULT '';
  DECLARE i INT DEFAULT 0;#declare相当于声明变量,给变量默认值,要加分号
  WHILE i < n DO#循环体开始,i从0开始
    SET return_str=CONCAT(return_str,SUBSTRING(chars_str,FLOOR(1+RAND()*52),1));#截取52随机数后面的一个字母作为返回结果
    SET i=i + 1;#值的变化要在前面加set,而且现在要分号了,循环体里
    END WHILE;#结束循环标志
    RETURN return_str;返回值要写
END //函数体结束的标志
DELIMITER;#回归MySQL正常语句的模式

#函数2:创建随机数据数据必需的随机数
DELIMITER //
CREATE FUNCTION rand_num (from_num INT,to_num INT) RETURNS INT(11)
BEGIN
DECLARE i INT DEFAULT 0;
SET i = FLOOR(from_num + RAND()*(to_num - from_num + 1));
RETURN i;
END //
DELIMITER;

rand(0,1)中取小数,乘以52可以将区间扩大(0,52),floor是向下取整区间为(1,52),substring(str,begin,len),在str字符串中,从begin开始截取长度为len的字符串,不包括begin起始点的字符

三、创建要使用的存储过程


DELIMITER //
CREATE PROCEDURE insert_course( max_num INT)#创建存储过程,与函数关键字不一样
BEGIN
DECLARE i INT DEFAULT 0;
SET autocommit = 0 ;#设置手动提交事务
REPEAT #循环开始标志
SET i = i + 1;
INSERT INTO course (course_id, course_name ) VALUES ( rand_num(10000,10100),rand_string(6));#插入10000到10100之间的随机数和大小字母中的随意6个字符
UNTIL i = max_num#循环条件
END REPEAT;#结束循环标志
COMMIT;#持久化
END //
DELIMITER;


DELIMITER //
CREATE PROCEDURE insert_stu( max_num INT)
BEGIN
DECLARE i INT DEFAULT 0;
SET autocommit = 0;
REPEAT
SET i = i + 1;
INSERT INTO student_info (course_id, class_id,student_id, NAME ) VALUES 
(rand_num(10000,10100),rand_num(10000,10200),rand_num(1,200000),rand_string(6));#插入随机数10000~10100之间的随机数,10000~10200之间的随机数,1~200000之间的随机数,大小字母中的随机6个字符
UNTIL i = max_num
END REPEAT;
COMMIT;
END //
DELIMITER;

三、调用的存储过程

CALL insert_course(100);
SELECT COUNT(*) FROM course;#查看是否添加成功
CALL insert_stu(1000000);
1 queries executed, 1 success, 0 errors, 0 warnings
查询:call insert_stu(1000000)0 行受到影响
执行耗时   : 47.357 sec
传送时间   : 0 sec
总耗时      : 47.358 sec
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值