mysql8创建函数循环插入100万条数据

--首先创建表
-- zhy.student definition

CREATE TABLE `student` (
  `id` bigint unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT '' COMMENT '用户名称',
  `email` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '邮箱',
  `phone` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT '' COMMENT '电话',
  `gender` tinyint unsigned NOT NULL COMMENT '1:男; 0:女',
  `password` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '密码',
  `age` tinyint DEFAULT '0' COMMENT '年龄',
  `create_time` datetime DEFAULT CURRENT_TIMESTAMP,
  `update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1000003 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='学生表';
-- 1. 先执行 删除函数语句
DROP FUNCTION IF EXISTS mock_data;

-- 2. 然后执行 创建函数
-- 插入100万条数据 
CREATE FUNCTION mock_data()
RETURNS INT
BEGIN
	DECLARE num int default 1000000;
	DECLARE i int default 0;
	WHILE i<num DO
		INSERT INTO `zhy`.`student`(`name`,`email`,`phone`,`gender`,`password`,`age`)VALUES(CONCAT('用户',i),'8563967666@qq.com',concat('18',floor(RAND()* 999999999)),floor(RAND()* 2),uuid(),floor(RAND()* 100));
	SET i = i+1;
	END WHILE;
	RETURN i;
end;

// 3. 最后调用创建好的函数
select  mock_data();
  • 然后给表某个字段加上索引 可以对比下执行速度
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值