0

0

MySQL-procedure(loop,repeat)_MySQL

php中文网

php中文网

发布时间:2016-05-30 17:11:10

|

1265人浏览过

|

来源于php中文网

原创

在 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次

 

drop procedure if exists proctx;
 create procedure proctx()
begin
 declare xid int;-- 随机来源id
 declare xstr varchar(1);-- 来源id对应的单字
declare oid int;-- 字符串随机增长计数
 declare xostr varchar(10);-- 字符串结果
 declare txid int;-- 全体循环计数
set txid=0;
truncate tx;

 loop1:loop
set txid=txid+1;
 set oid=ceil(rand()*10);--  用随机生成的循环次数来决定字符的长度
 set xostr='';-- 在进入增长循环前要定为空字符串,否则默认为null,concat连null的结果都是null

 repeat
set xid=ceil(rand()*1023);
 select t into xstr from t where id=xid;
 set xostr=CONCAT(xstr,xostr);-- 最终要插入 tx 表的字符串结果
 set oid=oid-1;
 until oid=0 end repeat;
 
 insert into tx set x=xostr;-- 增长结束后插入表
 if txid>=50000 then leave loop1;end if;
 end loop;
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松戏                |

| 扁                   |

| 订卖柜试击比所店     |

Diagrimo
Diagrimo

AI信息图生成、图表制作

下载

| 濕如个               |

| 癣表亿               |

| 龙石周价险           |

| {糯                  |

| 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语句执行时间侧重循环和随机了大概是。虽然没有检验出两种引擎的特点,但是生成随机字符串的目的还是达到了,就是性能有待优化。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

2

2026.02.27

Golang 高级特性与最佳实践:提升代码艺术
Golang 高级特性与最佳实践:提升代码艺术

本专题深入剖析 Golang 的高级特性与工程级最佳实践,涵盖并发模型、内存管理、接口设计与错误处理策略。通过真实场景与代码对比,引导从“可运行”走向“高质量”,帮助构建高性能、可扩展、易维护的优雅 Go 代码体系。

1

2026.02.27

Golang 测试与调试专题:确保代码可靠性
Golang 测试与调试专题:确保代码可靠性

本专题聚焦 Golang 的测试与调试体系,系统讲解单元测试、表驱动测试、基准测试与覆盖率分析方法,并深入剖析调试工具与常见问题定位思路。通过实践示例,引导建立可验证、可回归的工程习惯,从而持续提升代码可靠性与可维护性。

0

2026.02.27

漫蛙app官网链接入口
漫蛙app官网链接入口

漫蛙App官网提供多条稳定入口,包括 https://manwa.me、https

56

2026.02.27

deepseek在线提问
deepseek在线提问

本合集汇总了DeepSeek在线提问技巧与免登录使用入口,助你快速上手AI对话、写作、分析等功能。阅读专题下面的文章了解更多详细内容。

4

2026.02.27

AO3官网直接进入
AO3官网直接进入

AO3官网最新入口合集,汇总2026年可用官方及镜像链接,助你快速稳定访问Archive of Our Own平台。阅读专题下面的文章了解更多详细内容。

53

2026.02.27

php框架基础教程
php框架基础教程

本合集涵盖2026年最新PHP框架入门知识与基础教程,适合初学者快速掌握主流框架核心概念与使用方法。阅读专题下面的文章了解更多详细内容。

1

2026.02.27

php框架怎么用
php框架怎么用

本合集专为零基础学习者打造,系统介绍主流PHP框架的安装、配置与基础用法,助你快速入门Web开发。阅读专题下面的文章了解更多详细内容。

4

2026.02.27

无禁词AI聊天软件下载大全
无禁词AI聊天软件下载大全

本合集精选多款免费、无违禁词限制的AI聊天软件,支持自定义角色、剧情畅聊,体验真实互动感。阅读专题下面的文章了解更多详细内容。

19

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号