Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/64.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
同时进行随机插入和删除的mysqlslap测试_Mysql_Performance Testing_Sqlperformance - Fatal编程技术网

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

同时进行随机插入和删除的mysqlslap测试,mysql,performance-testing,sqlperformance,Mysql,Performance Testing,Sqlperformance,我有一张桌子 create table slap(ind char(4) primary key, name varchar(50)); 我想用一系列随机插入和删除来测试这一点,查询将由一个sql文件提供,其中包含10000条插入/删除语句,看起来像- insert into slap values('gdvx', 'gdvx'); delete from slap where ind='gdvx'; insert into slap values('sbkq', 'sbkq'); delet

我有一张桌子

create table slap(ind char(4) primary key, name varchar(50));
我想用一系列随机插入和删除来测试这一点,查询将由一个sql文件提供,其中包含10000条插入/删除语句,看起来像-

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是否支持这样的东西


谢谢

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

我认为您无法协调线程执行哪个查询。但是,您可以编辑查询文件并将关键字“insert”更改为关键字“insert ignore”。这样,重复的键错误将被视为警告,而不是错误。谢谢…我用python做的…将尝试一下。