mysqlslap测试同时进行随机插入和删除

时间:2018-04-19 17:37:55

标签: mysql performance-testing sqlperformance

我有一张桌子

create table slap(ind char(4) primary key, name varchar(50));

我想用一系列随机插入和删除来测试这个,查询将由包含10000个插入/删除语句的sql文件提供,看起来像 -

insert into slap values('gdvx', 'gdvx');
delete from slap where ind='gdvx';
insert into slap values('sbkq', 'sbkq');
delete from slap where ind='sbkq';
insert into slap values('gdmb', 'gdmb');
insert into slap values('vnka', 'vnka');
insert into slap values('mytw', 'mytw');
delete from slap where ind='gdmb';

我正在运行mysqlslap命令

mysqlslap --concurrency=50 --iterations=1 --query=./slaptest.sql --create-schema=slaptest -uroot -p

我得到错误作为重复键插入,因为我相信每个线程从文件的开始执行查询,但我希望线程顺序执行来自此文件的查询,即第一个线程执行第一个语句和第二个线程第二个语句等。

如果mysqlslap支持这样的话,请告诉我吗?

由于

1 个答案:

答案 0 :(得分:2)

mysqlslap无法做你想做的事:根据主题编号跳过一些行:

可是:

您可以将它放在SQL脚本中,并获取要使用的四个字母数字字符的随机字符串。

set @randomval := substring(to_base64(
                      concat(char(round(rand()*25)+97),
                      char(round(rand()*25)+97),
                      char(round(rand()*25)+97),
                      char(round(rand()*25)+97))),1,4)
insert ignore into slap values(@randomval , @randomval );
delete from slap where ind=@randomval ;

根据需要多次重复这些行。

ind键只有四个字符, 会发生一些冲突:一些随机值会相同。因此insert ignore