mysqlslap测试并发随机插入和删除

标签 mysql performance-testing sqlperformance

我有一张 table

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

谢谢

最佳答案

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

关于mysqlslap测试并发随机插入和删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49927044/

相关文章:

php - MySQL 插入查询进度变慢

php - 从 PHP 数据库中检索数据

javascript - 为什么用 null 初始化对象的属性会提高速度?

sql-server - 聚集列存储索引会影响 SSAS 查询最终用户性能吗

sql-server - SQL Server : Geography search performance - query nearest stores

php - 使用 LIKE 运算符优化 10k 记录的 mysql 查询

php - 如何为与其他字段名称相同的字段创建别名?

testing - 如何在 linux 服务器中暂停以非 gui 模式运行的 Jmeter

mysql - 使用 GROUP BY 优化查询以删除 Using Temporary;使用文件排序

php - mysql统计字段中特殊字符的出现次数