您好,登錄后才能下訂單哦!
往身份信息表插入N條記錄,N=P*Q,
p:每條insert語(yǔ)句插入的記錄數(shù),由臨時(shí)表的數(shù)量決定
q:循環(huán)次數(shù),存儲(chǔ)過(guò)程的入?yún)?/p>
-- 身份信息表
drop table if exists t_identity_info;
create table t_identity_info
(id
int(11) not null auto_increment comment '主鍵id',real_name
varchar(20) default null comment '姓名',id_card
varchar(18) not null comment '×××號(hào)',create_time
varchar(19) not null comment '創(chuàng)建時(shí)間',
primary key (id
),
key index_id_card
(id_card
)
) engine=innodb auto_increment=1 default charset=utf8 comment='用戶信息表';
-- 刪除
drop function if EXISTS rand_xing_ming ;
-- 創(chuàng)建函數(shù)
create function rand_xing_ming() returns varchar(20)
begin
declare xing_string varchar(1000) default '趙錢孫李周吳鄭王馮陳';
declare ming_string varchar(1000) default '天地玄黃宇宙洪荒日月';
declare xing_ming varchar(20) default '' ;
declare xing_index int;
declare ming_index int;
declare temp_xing varchar(10);
declare temp_ming varchar(10);
set xing_index = round(rand()10000) mod (char_length(xing_string)-1);
set ming_index = (round(rand()10000)) mod (char_length(ming_string)-1);
set temp_xing = substring(xing_string,xing_index,1);
set temp_ming = substring(ming_string,ming_index,1);
set xing_ming = concat(temp_xing,temp_ming);
return xing_ming;
end
;
-- 測(cè)試
select rand_xing_ming();
-- 臨時(shí)表,用來(lái)控制insert的條數(shù)
drop table if exists t_temp;
create table t_temp (
id int(11) not null auto_increment comment '主鍵id',
primary key (id)
) engine=innodb auto_increment=1 default charset=utf8 comment='臨時(shí)表';
-- 插入100條數(shù)據(jù)
insert into t_temp values
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),(),
(),(),(),(),(),(),(),(),(),();
-- 存儲(chǔ)過(guò)程
drop procedure if exists insert_data;
delimiter ;;
create procedure insert_data(IN data_count int)
begin
declare i int;
set i = 0;
while i < data_count do
set i = i +1;
insert into t_identity_info (real_name,id_card,create_time)
select rand_xing_ming(),'abc',now() from t_temp ;
end while;
end
;;
DELIMITER ;
-- 調(diào)用存儲(chǔ)過(guò)程 插入10W條記錄
set autocommit= 0;
call insert_data(1000);
commit;
-- 驗(yàn)證
select count(1) from t_identity_info;
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。