MySQL-procedure(loop,repeat)_MySQL
在 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松戏 |
| 扁 |
| 订卖柜试击比所店 |
| 濕如个 |
| 癣表亿 |
| 龙石周价险 |
| {糯 |
| 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 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL에서 파티셔닝, 샤딩, 인덱싱 및 쿼리 최적화를 포함하여 대규모 데이터 세트를 처리하기위한 전략에 대해 설명합니다.

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].

이 기사에서는 Drop Table 문을 사용하여 MySQL에서 테이블을 떨어 뜨리는 것에 대해 설명하여 예방 조치와 위험을 강조합니다. 백업 없이는 행동이 돌이킬 수 없으며 복구 방법 및 잠재적 생산 환경 위험을 상세하게합니다.

기사는 외국 열쇠를 사용하여 데이터베이스의 관계를 나타내고 모범 사례, 데이터 무결성 및 피할 수있는 일반적인 함정에 중점을 둡니다.

이 기사에서는 PostgreSQL, MySQL 및 MongoDB와 같은 다양한 데이터베이스에서 JSON 열에서 인덱스를 작성하여 쿼리 성능을 향상시킵니다. 특정 JSON 경로를 인덱싱하는 구문 및 이점을 설명하고 지원되는 데이터베이스 시스템을 나열합니다.

기사는 준비된 명령문, 입력 검증 및 강력한 암호 정책을 사용하여 SQL 주입 및 무차별 적 공격에 대한 MySQL 보안에 대해 논의합니다 (159 자)
