介绍
是否曾经发现自己处于需要大量虚拟数据进行测试,但又不想花费数小时编写脚本或手动插入记录的情况?或者您可能对如何利用 MySQL 8.0 中的新功能来简化数据库任务感到好奇?好吧,你可要好好享受一下了!在这篇文章中,我们将探索如何使用通用表表达式 (CTE) 轻松生成大量虚拟数据并将其插入到 MySQL 数据库中。
想象一下需要在表中填充一百万个哈希值以进行负载测试或性能基准测试。听起来像一场噩梦,对吧?不再!随着 MySQL 8.0 中 CTE 的出现,您可以在几秒钟内实现这一目标。让我们深入了解它的工作原理以及如何使用这个强大的功能来简化您的数据生成需求。
TL; DR
公用表表达式(CTE)是MySQL 8.0中添加的新功能,可以用来轻松输入大量简单的虚拟数据。例如,如果您想将 100 万条虚拟数据输入到一个存储哈希值的名为 hashes 的表中,您可以通过以下步骤实现:
表定义
首先,创建表:
创建表哈希( id INT 主键自动递增, 哈希 CHAR(64) );登录后复制
查询执行
设置会话变量以允许更高的递归深度:
设置会话cte_max_recursion_深度= 1000000;登录后复制 登录后复制
然后,执行CTE插入100万行:
插入哈希值(hash) 带有递归 cte (n) AS ( 选择1 联合所有 从 cte 中选择 n + 1,其中 n < 1000000> 登录后复制 登录后复制此方法利用递归公用表表达式来生成虚拟数据。
了解 CTE
公共表表达式(CTE)是一个命名的临时结果集,可以在单个语句中多次引用。 CTE 对于简化复杂查询和提高可读性特别有用。
语法细目
设置递归深度
设置会话cte_max_recursion_深度= 1000000;登录后复制 登录后复制cte_max_recursion_depth系统变量设置递归的上限。默认情况下,它是1000,所以要递归更多,你需要调整它。在这里,我们将其设置为 100 万。
CTE 查询
插入哈希值(hash) 带有递归 cte (n) AS ( 选择1 联合所有 从 cte 中选择 n + 1,其中 n < 1000000> 登录后复制 登录后复制让我们分解这个查询:
使用递归 cte (n):这将启动 CTE 定义。 cte是临时结果集的名称,n是列。
SELECT 1:这是CTE的非递归部分,作为起点(初始值)。
UNION ALL SELECT n + 1 FROM cte WHERE n
SELECT SHA2(n, 256) FROM cte:查询的最后部分选择每个 n 值的 SHA-256 哈希,生成用于插入的虚拟数据。
怎么运行的
CTE 递归生成从 1 到 1,000,000 的数字。对于每个数字,它计算 SHA-256 哈希值并将其插入哈希表中。这种方法非常高效,并且利用 MySQL 的递归功能来无缝处理大数据量。
处理速度
验证环境
为了了解此功能的影响,我使用了 Gitpod Enterprise 工作区,利用强大且短暂的环境来避免设置和安装的麻烦。这是设置的概览:
- 机器:Gitpod Enterprise XXLarge 工作区
- 操作系统:Ubuntu 22.04.4 LTS(Jammy Jellyfish)
- 容器化:Docker 版本 26.0.1
- MySQL 版本:官方 MySQL 8.0 Docker 镜像
结果
对于 100 万行,查询执行时间约为 4.46 秒:
mysql> INSERT INTO 哈希值(hash) -> 带有递归 cte (n) AS -> ( -> 选择 1 -> 联合所有 -> 从 cte 中选择 n + 1,其中 n < 1000000> ) -> 从 cte 中选择 SHA2(n, 256); 查询正常,1000000 行受影响(4.43 秒) 记录:1000000 重复:0 警告:0登录后复制
性能指标
行数 | 执行时间 |
---|---|
1,000 | 0.03秒 |
10,000 | 0.07秒 |
100,000 | 0.42秒 |
1,000,000 | 4.43秒 |
10,000,000 | 48.53秒 |
结论
在 MySQL 8.0 中使用 CTE 改变了游戏规则,可以快速生成大量虚拟数据。它对于负载测试和性能基准测试特别方便。只需几行代码,您就可以轻松填充表格,然后返回项目的其他重要部分。
不要犹豫,尝试不同的数据生成策略和递归深度,看看哪种最适合您。有关安全性和日志分析的更多提示和见解,请在 Twitter 上关注我@Siddhant_K_code,并随时了解此类最新且详细的技术内容。快乐编码!
以上就是如何在MySQL中大规模注入简单的虚拟数据的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » 如何在MySQL中大规模注入简单的虚拟数据
发表评论 取消回复