MySQL-procedure(loop,repeat)

本文详细介绍了如何使用MySQL存储过程将指定表中的文本分割并存储到另一个表中,形成一个字符库,并以此为基础生成不定长随机字符串。通过对比InnoDB和MyISAM引擎的性能,发现生成随机字符串的过程较为耗时。优化过程包括确保字符串变量初始化,以避免插入null值,并通过实验观察到两种引擎在执行速度上的差异。最终实现了随机字符串的生成,但强调性能优化的空间仍然存在。

AI 时代程序员必备技能

Codex、Claude Code、Cursor、Hermes Agent、OpenClaw等工程化实战专栏 ,讲透 AI 如何接管脏活累活

MySQL-procedure(cursor,loop) 中将spam_keyword表中的文字全部分割到t表当中,且每一行的字都不重复,那t表可以用来当作一个小字典,只有1000来个字符,这次把t表当作字符来源,写一个”以 t 表为字符库生成不定长随机字符的procedure“。

1、t表使用的是InnoDB引擎,为了有个区别比较,再新建一个t2表,用MyISAM引擎并复制t的数据,共1023行记录

create table t2 like t;
alter table t2 engine=myisam;
insert into t2 select *from t;
CREATE TABLE `t2` (
  `id` int(11) DEFAULT NULL,-- 行号id,不重复,共1023行
  `t` varchar(3) DEFAULT NULL,
  `cnt` int(11) DEFAULT NULL,
  KEY `idx_id` (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

2、再建一个表,放放生成的随机数据,表名 tx ,列 x ,每行存放0到10个字符。

CREATE TABLE `tx` (
  `x` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8

3、存储过程,用rand()生成10以内的随机数来确定每个插入字符串的长度,插入50000次

 1 drop procedure if exists proctx;
 2 create procedure proctx()
 3 begin
 4 declare xid int;-- 随机来源id
 5 declare xstr varchar(1);-- 来源id对应的单字
 6 declare oid int;-- 字符串随机增长计数
 7 declare xostr varchar(10);-- 字符串结果
 8 declare txid int;-- 全体循环计数
 9 set txid=0;
10 truncate tx;
11 
12 loop1:loop
13 set txid=txid+1;
14 set oid=ceil(rand()*10);--  用随机生成的循环次数来决定字符的长度
15 set xostr='';-- 在进入增长循环前要定为空字符串,否则默认为null,concat连null的结果都是null
16 
17 repeat
18 set xid=ceil(rand()*1023);
19 select t into xstr from t where id=xid;
20 set xostr=CONCAT(xstr,xostr);-- 最终要插入 tx 表的字符串结果
21 set oid=oid-1;
22 until oid=0 end repeat;
23 
24 insert into tx set x=xostr;-- 增长结束后插入表
25 if txid>=50000 then leave loop1;end if;
26 end loop;
27 end;

写过程中一开始没有注意要set xostr ,给这个字符串变量一个初始值,使它在后面的concat函数中的结果都变成了null,结果就是在tx表中插入了全是null

4、call proctx 后看结果

从 t 表,InnoDB,441.677s,7 min 21 s,113.205 lines per sec

[SQL]call proctx()

受影响的行: 1
时间: 441.677s
mysql> select * from tx;
+----------------------+
| x                    |
+----------------------+
| 灾#中育知斑列灯郎    |
| 无降                 |
| u松戏                |
||
| 订卖柜试击比所店     |
| 濕如个               |
| 癣表亿               |
| 龙石周价险           |
| {糯                  |
| Q门装寄司口附妻     |
......省略......

修改过程,从 t2 表,MyISAM,439.339s,7 min 19 s,113.895 lines per sec

[SQL]call proctx()

受影响的行: 1
时间: 439.339s
mysql> select * from tx;
+----------------------+
| x                    |
+----------------------+
| 象死宫势拍李反       |
| p南展                |
| 分进卡               |
| 旗接酒z弱乐晗揭      |
| 好富正奇阴园找缩     |
| 风G起旗.证雅于       |
| 计w合                |
| 郑麻债空义海门箱招生 |
||
| 你高干加六非认自徐   |
......省略......

两个执行结果没有差距,不能说明什么问题,而且由于两次执行过程中实际产生的循环操作次数应该是不一样的,因为随机数的不同,其实两个结果的可比性还和随机数的性质有关联。另外仅仅是5w条的随机数用了7分多钟,实在是慢了点。如果能在几分钟内完成5kw的插入,说不定还能将随机数对时间产生的影响比例缩小,“那就得看这个随机到底是真随机还是假随机了”,两个引擎客观上应该是存在查询性能不同的特点的,但是这次这个试验应该是用错了测验对象,t 表记录量少,procedure语句执行时间侧重循环和随机了大概是。虽然没有检验出两种引擎的特点,但是生成随机字符串的目的还是达到了,就是性能有待优化。

转载于:https://www.cnblogs.com/right-dress/p/4805047.html

AI 时代程序员必备技能

Codex、Claude Code、Cursor、Hermes Agent、OpenClaw等工程化实战专栏 ,讲透 AI 如何接管脏活累活

本数据集来源于 2024 年 7 月在江西省中东部余干县、贵溪市、金溪县丘陵林地采集的千枚岩、红砂岩、花岗岩母质发育红壤关键带剖面土壤实测数据,空间覆盖 3 个县域不同岩性风化壳林地,采样点位经纬度分别为千枚岩剖面 P10(116.8316°E,28.5269°N)、红砂岩剖面 P08(117.1048°E,28.3492°N)、花岗岩剖面 P04(116.6883°E,27.9963°N);垂直空间采样深度存在差异,千枚岩与花岗岩剖面采样深度 0~600 cm,红砂岩剖面采样深度 0~450 cm,垂直分层采样分辨率为 0~50 cm 区间分 0~20 cm、20~50 cm 两层,50 cm 以下土层以 50 cm 为固定间隔分层,整套数据集共包含 36 条土壤剖面分层记录,其中 P10 千枚岩剖面 13 条、P08 红砂岩剖面 11 条、P04 花岗岩剖面 13 条。数据采集时间为 2024 年 7 月,实验室理化指标、矿物测试、酸碱滴定及统计建模工作于 2024 年 7 月 —2026 年 5 月完成,无时间序列连续监测数据,仅为单次野外剖面采样静态数据集。 数据集包含野外剖面基础信息、土壤酸碱滴定原始数据、土壤酸度指标、交换性盐基与交换性酸、土壤机械组成、有机质、黏土与原生矿物半定量 XRD 数据、无定形 / 晶形铁铝氧化物含量。全量理化指标计量单位统一规范:酸缓冲容量 pHBC 单位为 cmol・kg⁻¹・pH⁻¹,交换性酸、交换性盐基离子单位为 cmol・kg⁻¹,矿物以质量百分比(%)表示,、黏粒 / 粉粒 / 砂粒、有机质、铁铝氧化物单位均为g/kg,pH 为无量纲数值。 覆盖范围: 中位纬度: 28.2616 中位经度: 116.89654999999999 南界纬度: 27.9963 西界经度: 116.6883 北界纬度: 28.5269 东界经
【内容概要】 基于 Vite 6 与 TypeScript 5 严格模式构建的企业级前端工程化脚手架模板,开箱集成代码规范、单元测试、持续集成与容器化部署的完整链路。模板将 ESLint 9 扁平化配置、typescript-eslint 类型感知规则、Prettier 3 格式化、Vitest 2 单元测试(含 V8 覆盖率 80% 阈值)、Husky v9 + lint-staged 提交前钩子,以及 GitHub Actions 多版本 Node 矩阵流水线打通到位,另附多阶段 Dockerfile 与 nginx 静态托管配置,可在本地 pnpm install 或 docker compose up 直接启动。源码层面提供分级日志器 Logger、强类型事件总线 EventBus(基于 mitt)、Rust 风格 Result 类型、数字与字节时长格式化工具、可复用 Counter 组件等示例,并配套 32 个 Vitest 用例,演示如何在严格类型约束下编写可测试、可维护的工程化代码。 【适合人群】 1. 准备搭建中大型前端项目,需要一份可直接落地的工程化基线模板的全栈工程师; 2. 希望系统理解 Vite 构建配置、ESLint 9 扁平配置、Vitest 覆盖率门槛与 GitHub Actions 流水线如何串联的中级前端开发者; 3. 在团队中负责制定前端规范、CI 流程与 Docker 部署方案的技术负责人; 4. 学习 TypeScript 严格模式下编写类型安全工具库、组件、事件系统的实战示范的学习者。 【能学到什么】 1. Vite 6 + TypeScript 5 严格模式(strict、noUncheckedIndexedAccess、exactOptionalPropertyTypes)下的工程结构组织方式; 2. ESLint 9 Fl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值