mysqlslap测试并发随机插入和删除
mysqlslap test with random insertions and deletions concurrently
我有一个 table 作为
create table slap(ind char(4) primary key, name varchar(50));
我想用一系列随机插入和删除来测试它,查询将由一个包含 10000 个 inserts/delete 语句的 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';
我是 运行 我的 sqlslap 命令是
mysqlslap --concurrency=50 --iterations=1 --query=./slaptest.sql --create-schema=slaptest -uroot -p
我收到重复键插入错误,因为我相信每个线程都从文件的开头执行查询,但我希望线程按顺序从该文件执行查询,即第一个线程执行第一个语句,第二个线程执行第二个语句等。
请让我知道我的sqlslap是否支持这样的东西?
谢谢
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
.
我有一个 table 作为
create table slap(ind char(4) primary key, name varchar(50));
我想用一系列随机插入和删除来测试它,查询将由一个包含 10000 个 inserts/delete 语句的 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';
我是 运行 我的 sqlslap 命令是
mysqlslap --concurrency=50 --iterations=1 --query=./slaptest.sql --create-schema=slaptest -uroot -p
我收到重复键插入错误,因为我相信每个线程都从文件的开头执行查询,但我希望线程按顺序从该文件执行查询,即第一个线程执行第一个语句,第二个线程执行第二个语句等。
请让我知道我的sqlslap是否支持这样的东西?
谢谢
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
.