用mysql储存进程批量插入数据
发布时间:2021-01-13 04:26:55 所属栏目:编程 来源:网络整理
导读:本日PHP站长网 52php.cn把网络自互联网的代码分享给各人,仅供参考。 #数据表的布局为stu_id(学号) ,stu_name(姓名),stu_sex(性别),cla_id(班级编号),stu_phone(手机号)drop procedure if exists insertt;#
|
以下代码由PHP站长网 52php.cn网络自互联网 此刻PHP站长网小编把它分享给各人,仅供参考 #数据表的布局为stu_id(学号) ,stu_name(姓名),stu_sex(性别),cla_id(班级编号),stu_phone(手机号)
drop procedure if exists insertt;#假如存在储存进程则删除
delimiter $$ #建设一个储存进程
create procedure insertt()
begin
set @a=2000000001; #学号
set @d=20000001; #班级编号
set @e=18200000000; #手机号
while @a<2000010001 do #假如@a<2000010001则返回true,继承执行
set @b=rand_string(5); #姓名,随即赋值,值为5位a-zA-Z的恣意组合
set @c=rand_sex(1); #性别,随即赋值,值为1位,0可能1
insert into students values(@a,@b,@c,@d,@e);
set @[email?protected]+1;
set @[email?protected]+1;
if @a%100=0
then
set @[email?protected]+1 ;
end if;
end while;
end$$
delimiter ;
#执行存储进程插入数据
call insertt();
#建设一个随机发生字符串的函数
set global log_bin_trust_function_creators = 1;
DROP FUNCTION IF EXISTS rand_string;
DELIMITER //
CREATE FUNCTION rand_string(n INT)
RETURNS VARCHAR(255)
BEGIN
DECLARE chars_str varchar(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
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));#52代表在52个字母中随即找出一个
SET i = i +1;
END WHILE;
RETURN return_str;
END //
delimiter ;
#建设一个随机发生字符串的函数,0和1随机呈现
set global log_bin_trust_function_creators = 1;
DROP FUNCTION IF EXISTS rand_sex;
DELIMITER //
CREATE FUNCTION rand_sex(n INT)
RETURNS VARCHAR(255)
BEGIN
DECLARE chars_str varchar(100) DEFAULT '01';
DECLARE return_str varchar(255) DEFAULT '';
DECLARE i INT DEFAULT 0;
WHILE i < n DO
SET return_str = concat(return_str,FLOOR(1 + RAND()*2 ),1));
SET i = i +1;
END WHILE;
RETURN return_str;
END //
delimiter ;
以上内容由PHP站长网【52php.cn】网络清算供各人参考研究 假如以上内容对您有辅佐,接待保藏、点赞、保举、分享。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读


