广告
返回顶部
首页 > 资讯 > 数据库 >怎么用Mysql存储过程造百万级数据
  • 724
分享到

怎么用Mysql存储过程造百万级数据

2023-07-05 13:07:36 724人浏览 泡泡鱼
摘要

本文小编为大家详细介绍“怎么用Mysql存储过程造百万级数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Mysql存储过程造百万级数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.准备工作(1)由于

本文小编为大家详细介绍“怎么用Mysql存储过程造百万级数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Mysql存储过程造百万级数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1.准备工作

(1)由于是使用存储过程,mysql从5.0版开始支持存储过程,那么需要mysql的版本在5.0或者以上。如何查看mysql的版本,使用下面sql语句查看:

怎么用Mysql存储过程造百万级数据

(2)创建两张表,表结构一致,但使用的存储引擎不一样,如下所示,普通表使用mysql5.5版本后默认的INNODB存储引擎,内存表使用MEMORY存储引擎。

由于MEMORY存储不常用这里简单说一下其特点:MEMORY引擎表结构创建在磁盘上,数据全部放在内存中,访问速度较快,但是当MySQL重启后或者一旦系统奔溃的话,数据都会消失,结构还存在。

# 创建普通表CREATE TABLE `user_info` (    `id` INT ( 11 ) NOT NULL AUTO_INCREMENT COMMENT 'ID',    `name` VARCHAR ( 30 ) NOT NULL COMMENT '用户名',    `phone` VARCHAR ( 11 ) NOT NULL COMMENT '手机号',    `status` TINYINT ( 1 ) NULL DEFAULT NULL COMMENT '用户状态:停用0,启动1',    `create_time` datetime NOT NULL COMMENT '创建时间',    PRIMARY KEY ( `id` ) USING BTREE ) ENGINE = INNODB AUTO_INCREMENT = 10001 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '用户信息表'; # 创建内存表CREATE TABLE `memory_user_info` (    `id` INT ( 11 ) NOT NULL AUTO_INCREMENT COMMENT 'ID',    `name` VARCHAR ( 30 ) NOT NULL COMMENT '用户名',    `phone` VARCHAR ( 11 ) NOT NULL COMMENT '手机号',    `status` TINYINT ( 1 ) NULL DEFAULT NULL COMMENT '用户状态:停用0,启动1',    `create_time` datetime NOT NULL COMMENT '创建时间',    PRIMARY KEY ( `id` ) USING BTREE ) ENGINE = MEMORY AUTO_INCREMENT = 10001 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '用户信息内存表';

2.主要实现步骤

(1)创建自动生成数据的函数,插入时使用;

(2)创建插入内存表数据存储过程,调用已创建好的数据生成函数;

(3)创建内存表数据插入普通表存储过程;

(4)调用存储过程。

(5)数据查看验证

3.创建自动生成数据的函数

(1)生成n个随机数字

DELIMITER //DROP FUNCTioNIF    EXISTS randomNum // CREATE FUNCTION randomNum (        n INT,        chars_str VARCHAR ( 10 )) RETURNS VARCHAR ( 255 ) BEGIN    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()* 10 ), 1 ));                SET i = i + 1;            END WHILE;    RETURN return_str;    END // DELIMITER;

函数运行截图:

怎么用Mysql存储过程造百万级数据

脚本所用到的mysql函数及其功能如下:

a.concat():将多个字符串连接成一个字符串。

b.Floor():向下取整。

c.substring(string, position, length)

第一个参数:string指的是需要截取的原字符串。

第二个参数:position指的是从哪个位置开始截取子字符串,这里字符的位置编码序号是从1开始,若position为负数则从右往左开始数位置。

第三个参数:length指的是需要截取的字符串长度,如果不写,则默认截取从position开始到最后一位的所有字符。

d.RAND():只能生成0到1之间的随机小数。

(2)创建随机生成手机号函数

DELIMITER //DROP FUNCTIONIF    EXISTS getPhone // CREATE FUNCTION getPhone () RETURNS VARCHAR ( 11 ) BEGIN    DECLARE        head CHAR ( 3 );    DECLARE        phone VARCHAR ( 11 );    DECLARE        bodys VARCHAR ( 65 ) DEFAULT "130 131 132 133 134 135 136 137 138 139 186 187 189 151 157";    DECLARE        STARTS INT;        SET STARTS = 1+floor ( rand()* 15 )* 4;        SET head = trim(    substring( bodys, STARTS, 3 ));        SET phone = trim(        concat(            head,        randomNum ( 8, '0123456789' )));    RETURN phone;    END // DELIMITER;

函数运行截图:

怎么用Mysql存储过程造百万级数据

(3)创建随机生成用户名函数

DELIMITER //DROP FUNCTIONIF    EXISTS randName // CREATE FUNCTION randName ( n INT ) RETURNS VARCHAR ( 255 ) CHARSET utf8mb4 DETERMINISTIC BEGIN    DECLARE        chars_str VARCHAR ( 100 ) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';    DECLARE        return_str VARCHAR ( 30 ) DEFAULT '';    DECLARE        i INT DEFAULT 0;    WHILE            i < n DO                        SET return_str = concat(                return_str,            substring( chars_str, FLOOR( 1 + RAND() * 62 ), 1 ));                SET i = i + 1;            END WHILE;    RETURN return_str; END // DELIMITER;

函数运行截图:

怎么用Mysql存储过程造百万级数据

(4)随机生成用户状态函数

DELIMITER //DROP FUNCTIONIF    EXISTS randStatus // CREATE FUNCTION randStatus ( ) RETURNS TINYINT ( 1 ) BEGIN    DECLARE        user_status INT ( 1 ) DEFAULT 0;        SET user_status =    IF        ( FLOOR( RAND() * 10 ) <= 4, 1, 0 );    RETURN user_status; END // DELIMITER;

函数运行截图:

怎么用Mysql存储过程造百万级数据

(5)查看数据库中所有自定义函数信息

怎么用Mysql存储过程造百万级数据

4.创建存储过程

(1)创建插入内存表数据存储过程

DELIMITER //DROP FUNCTIONIF    EXISTS randStatus // CREATE FUNCTION randStatus ( ) RETURNS TINYINT ( 1 ) BEGIN    DECLARE        user_status INT ( 1 ) DEFAULT 0;        SET user_status =    IF        ( FLOOR( RAND() * 10 ) <= 4, 1, 0 );    RETURN user_status; END // DELIMITER;

入参n是多少就表示往内存表memory_user_info插入多少条数据

存储过程运行截图:

怎么用Mysql存储过程造百万级数据

(2)创建内存表数据插入普通表存储过程

DELIMITER //DROP PROCEDUREIF    EXISTS add_user_info // CREATE PROCEDURE `add_user_info` ( IN n INT, IN count INT ) BEGIN    DECLARE        i INT DEFAULT 1;    WHILE            ( i <= n ) DO            CALL add_memory_user_info ( count );        INSERT INTO user_info SELECT        *         FROM            memory_user_info;        DELETE         FROM            memory_user_info;                SET i = i + 1;            END WHILE; END // DELIMITER;

这是最主要的存储过程,也是入口,利用对内存表的循环插入和删除来实现批量生成数据,不需要更改mysql默认的max_heap_table_size值(默认值是16M),max_heap_table_size 的作用是配置用户创建内存临时表的大小,配置的值越大,能存进内存表的数据就越多。

存储过程运行截图:

怎么用Mysql存储过程造百万级数据

(3)查看存储过程的状态

-- 查看数据库所有的存储过程SHOW PROCEDURE STATUS;-- 模糊查询存储过程SHOW PROCEDURE STATUS LIKE 'add%';

模糊查询结果:

怎么用Mysql存储过程造百万级数据

5.调用存储过程

mysql称存储过程的执行为调用,因此mysql执行存储过程的语句为CALL。CALL接受存储过程的名字以及需要传递给它的任意参数。

通过调用add_user_info存储过程,不断循环插入内存表memory_user_info,再从内存表获取数据插入普通表user_info,然后删除内存表数据,以此循环直至循环结束。循环100次,每次生成10000条数据,共生成一百万条数据。

CALL add_user_info(100,10000);

6.数据查看验证

在普通表数据达到6万条时,已经耗时大概在23分钟左右,以这个时间推算,100万数据生成预计需要6小时左右。耗时的点主要是在四个随机生成字段数据的函数上。如果字段数据不要求随机,那么将会快很多。

怎么用Mysql存储过程造百万级数据

数据记录如下效果:

怎么用Mysql存储过程造百万级数据

读到这里,这篇“怎么用Mysql存储过程造百万级数据”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么用Mysql存储过程造百万级数据

本文链接: https://www.lsjlt.com/news/352043.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用Mysql存储过程造百万级数据
    本文小编为大家详细介绍“怎么用Mysql存储过程造百万级数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Mysql存储过程造百万级数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.准备工作(1)由于...
    99+
    2023-07-05
  • 一步步教你利用Mysql存储过程造百万级数据
    目录1.准备工作2.主要实现步骤3.创建自动生成数据的函数4.创建存储过程5.调用存储过程6.数据查看验证总结1.准备工作 (1)由于是使用存储过程,mysql从5.0版开始支持存储过程,那么需要mysql的版本在5.0...
    99+
    2023-03-19
    mysql存储过程怎么写 mysql 存储过程实例 MySQL创建存储过程
  • Mysql使用存储过程快速添加百万数据的示例代码
    前言 为了体现不加索引和添加索引的区别,需要使用百万级的数据,但是百万数据的表,如果使用一条条添加,特别繁琐又麻烦,这里使用存储过程快速添加数据,用时大概4个小时。 创建一个用户表 ...
    99+
    2022-11-12
  • MySQL数据库高级(四)——存储过程
    MySQL数据库高级(四)——存储过程 一、存储过程简介 1、存储过程简介 存储过程是一组具有特定功能的SQL语句集组成的可编程的函数,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数来调...
    99+
    2022-10-18
  • 百万级MySQL的数据量怎么快速完成数据迁移
    这篇文章主要讲解了“百万级MySQL的数据量怎么快速完成数据迁移”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“百万级MySQL的数据量怎么快速完成数据迁移”...
    99+
    2022-10-19
  • 怎么在mysql中优化百万级数据表的查询
    怎么在mysql中优化百万级数据表的查询?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.两种查询引擎查询速度(myIsam 引擎 )InnoDB 中不保存表的...
    99+
    2023-06-15
  • mysql存储过程数据怎么实现
    今天小编给大家分享一下mysql存储过程数据怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2023-05-25
    mysql
  • MySQL如何利用存储过程快速生成100万条数据详解
    前言 在测试的时候为了测试大数据量的情况下项目的抗压能力我们通常要创造一些测试数据那么现在这个方法绝对好用 其中可能会有sql空间的报错可以自己尝试解决,这里做了分批插入,每次插入3...
    99+
    2022-11-12
  • MySQL数据库之存储过程怎么创建
    本篇内容介绍了“MySQL数据库之存储过程怎么创建”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言:stored procedure 完成...
    99+
    2023-07-02
  • MySQL存储过程怎么循环插入数据
    这篇文章主要讲解了“MySQL存储过程怎么循环插入数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL存储过程怎么循环插入数据”吧!测试机器时经常要...
    99+
    2022-10-18
  • MySQL存储过程高级SQL语句怎么创建
    本篇内容主要讲解“MySQL存储过程高级SQL语句怎么创建”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL存储过程高级SQL语句怎么创建”吧!MySQL...
    99+
    2022-12-28
    mysql sql
  • MySQL中怎么使用存储过程
    MySQL中怎么使用存储过程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 mysql存储过程存储过程(Stored  P...
    99+
    2022-10-18
  • MySQL的存储过程怎么调用
    这篇文章主要讲解了“MySQL的存储过程怎么调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的存储过程怎么调用”吧!概述由MySQL5.0 版本开始支持存储过程。如果在实现用户的...
    99+
    2023-07-02
  • Oracle分页+付上Sql Server分页+千万级数据分页的存储过程是怎样的
    这篇文章给大家介绍Oracle分页+付上Sql Server分页+千万级数据分页的存储过程是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。select * from a...
    99+
    2022-10-18
  • mysql中怎么用存储过程&DataFactory准备测试数据
    小编给大家分享一下mysql中怎么用存储过程&DataFactory准备测试数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一...
    99+
    2022-10-18
  • MYSQL中存储过程和函数怎么写
    这篇文章将为大家详细讲解有关MYSQL中存储过程和函数怎么写,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是存储过程简单的说,就是一组SQL语句集,功能强大,可以实现...
    99+
    2022-10-18
  • MySQL存储过程和函数怎么创建
    这篇文章主要介绍“MySQL存储过程和函数怎么创建”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL存储过程和函数怎么创建”文章能帮助大家解决问题。1.0  创建存储过程和函数创建存...
    99+
    2023-06-30
  • mysql数据库中的存储过程是什么
    这篇文章给大家分享的是有关mysql数据库中的存储过程是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。mysql存储过程是在大型数据库系统中,一组为了完成特定功能的SQL 语...
    99+
    2022-10-18
  • 怎么写数据库的存储过程
    今天就跟大家聊聊有关怎么写数据库的存储过程,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  SQL语句需要先编译然后执行,而存储过程(Stored ...
    99+
    2022-10-18
  • 数据库怎么加密存储过程
    在数据库中对存储过程进行加密的方法首先,数据库中进行一个存储过程;CREATE PROCEDURE dbo.myPRoAS BEGINSELECT 'SQL statements'ENDGO存储过程新建好后,执行以下命令即可对存储过程进行加...
    99+
    2022-10-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作