JMeter JDBC请求Query Type实测(金仓数据库版)

news2025/5/23 7:44:17
文章目的

在实际性能测试中,JMeter的JDBC Request组件常用于模拟数据库操作。但许多用户对Query Type参数的具体行为存在疑惑。
本文将以金仓数据库KingbaseES为例,通过实测验证每种Query Type的行为,帮助用户明确其使用场景和限制,避免因配置不当导致测试结果失真。


一、测试环境准备

  1. JMeter配置

    • JMeter 5.3
    • JDBC驱动:kingbase8-9.0.0.jar(放置于jmeter/lib/ext目录)
  2. 数据库配置

    • KINGBASE (KingbaseES) V009R001C002B0014
    • 测试表结构:
      CREATE TABLE users (
        id SERIAL PRIMARY KEY,
        name VARCHAR(50),
        status VARCHAR(20) DEFAULT 'active'
      );
      insert into users(name) values ('user1');
      insert into users(name) values ('user2');
      
  3. JDBC连接配置

    • Variable Name: kingbase
    • Database URL: jdbc:kingbase8://192.168.17.12:54321/kingbase
    • JDBC Driver Class: com.kingbase8.Driver
    • 用户名/密码:根据实际填写 在这里插入图片描述

二、测试用例与实测过程

1. Select Statement
  • 测试目的
    验证执行多条SELECT语句时是否仅返回第一条结果。
  • 测试步骤
    1. 在JDBC Request中配置:
      • Query Type: Select Statement
      • SQL Query:
        SELECT * FROM users WHERE status='active';  -- 表中有2条active数据  
        SELECT * FROM users WHERE status='deleted'; -- 表中有1条deleted数据  
        
        数据库查询结果
        在这里插入图片描述
  1. 添加View Results Tree查看响应。

在这里插入图片描述
这里发现直接报错
在这里插入图片描述
删除查询语句后面的分号,只保留第1条查询语句
在这里插入图片描述
结果显示正常
在这里插入图片描述
后面如果再加sql语句,会因为没有分号报语法错误

结论 Select Statement仅可以执行一条SELECT语句


2. Update Statement
  • 测试目的
    验证执行多条DML语句时是否仅生效第一条。
  • 测试步骤
    1. 初始化数据:清空users表,插入一条数据:INSERT INTO users (name) VALUES ('test_user');
      在这里插入图片描述

    2. 配置JDBC Request:

      • Query Type: Update Statement
      • SQL Query:
        UPDATE users SET name='updated_user' WHERE id=1;  
        DELETE FROM users WHERE id=1;  
        

在这里插入图片描述 在这里插入图片描述

  1. 执行后检查数据库数据。
  • 执行结果

    • 语句全部执行成功
  • 结论
    Update Statement可以执行多条DML语句。


3. Callable Statement
  • 测试目的
    验证是否支持执行多语句或调用存储过程。
  • 测试步骤
    1. 创建PostgreSQL存储过程:
CREATE OR REPLACE PROCEDURE reset_users() AS 
BEGIN
UPDATE users SET name='default';  
DELETE FROM users WHERE status='deleted';  
END;   
 2. 配置JDBC Request:  
    - Query Type: `Callable Statement`  
    - SQL Query:  
      ```sql
      call reset_users();  -- 调用存储过程  
      SELECT * FROM users;    -- 查询结果  

在这里插入图片描述

执行前数据
在这里插入图片描述
3. 执行后检查数据库状态及响应数据。

  • 执行结果

    • 存储过程成功执行,所有用户name被重置为default
    • 响应数据中返回SELECT查询结果。
      在这里插入图片描述
  • 结论
    Callable Statement支持多语句和存储过程调用。


4. Prepared Select Statement
  • 测试目的
    验证参数化查询是否生效,并支持重复执行。

  • 测试步骤

    1. 配置JDBC Request:
      • Query Type: Prepared Select Statement
      • SQL Query: SELECT * FROM users WHERE id=?;
      • Parameter Values: ${__Random(1,5)}
      • Parameter Types: INTEGER
    2. 使用${__Random(1,5)}动态生成id值,循环执行2次。
    3. 检查每次查询是否返回匹配结果。
      在这里插入图片描述
  • 执行结果

    • 每次均能根据动态id值返回对应数据(若存在)。
      在这里插入图片描述
      在这里插入图片描述
  • 结论
    Prepared Select Statement支持参数化,提升重复查询性能。


5. Commit与Rollback
  • 测试目的
    验证手动提交与回滚事务的功能。

  • 测试步骤
    添加配置:
    第一个JDBC Request:AutoCommit(false)
    sql
    INSERT INTO users (name) VALUES (‘temp_user’);
    第二个JDBC Request:Rollback
    执行后检查数据库是否插入数据。

  • 执行结果
    执行后数据库无temp_user数据,回滚生效。

  • 结论
    通过Commit和Rollback可手动控制事务。


三、实测总结

Query Type支持多语句适用场景注意事项
Select Statement单次SELECT查询仅首条生效
Update Statement✔️多次INSERT/UPDATE/DELETE
Callable Statement✔️存储过程、多语句操作语法需符合数据库规范
Prepared Statement参数化重复查询或更新必须定义参数类型
Commit/Rollback-手动事务控制需先关闭AutoCommit

通过本次实测,可明确不同Query Type的行为差异。建议在性能测试中优先使用预编译语句(Prepared Statement)提升效率,并合理利用事务控制保证数据一致性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2383728.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【内部教程】ISOLAR-AB配置以太网栈|超详细实战版

目录 往期推荐 缩写与定义 关于系统描述(System Description) 1.1 EthCommunicationController 1.2 EthCommunicationConnector 1.2.1 Ports(端口) 1.3 EthPhysicalChannel(以太网物理通道) 1.3.1…

Nginx 核心功能

目录 一:正向代理 1:编译安装 Nginx (1)安装支持软件 (2)创建运行用户、组和日志目录 (3)编译安装 Nginx (4)添加 Nginx 系统服务 2:配置正…

【Canvas与图标】圆角方块蓝星CSS图标

【成图】 120*120的png图标 大小图&#xff1a; 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>圆角方块蓝星CSS Draft1</…

机器学习 day05

文章目录 前言一、模型选择与调优1.交叉验证2.超参数搜索 前言 通过今天的学习&#xff0c;我掌握了机器学习中模型的选择与调优&#xff0c;包括交叉验证&#xff0c;超参数搜索的概念与基本用法。 一、模型选择与调优 模型的选择与调优有许多方法&#xff0c;这里主要介绍较…

C#新建打开文件对话框

这是Winform直接封装好的打开文件对话框 using System.Windows.Forms; public static string OpenFile(string path) {OpenFileDialog openFileDialog new OpenFileDialog();// 设置对话框属性openFileDialog.Title "选择文件";openFileDialog.InitialDirectory …

汇川PLC通过开疆智能Profinet转ModbusTCP网关读取西门子PLC数据案例

本案例是客户通过开疆智能Profient转ModbusTCP网关连接汇川PLC的配置案例 Modbus TCP主站即Modbus TCP客户端&#xff0c;Modbus TCP主站最多支持同时与31个Modbus TCP从站 。&#xff08;Modbus TCP服务器&#xff09;进行通信。 第一步设置PLC IP地址&#xff1b; 默认PLC…

零基础入门:MinerU 和 PyTorch、CUDA的关系

&#x1f4a1;一句话总结&#xff1a;MinerU 是一个用 PyTorch 跑模型的程序&#xff0c;PyTorch 支持多种加速方式&#xff08;如 CUDA、MPS&#xff09;&#xff0c;让它跑得快就需要依赖这些加速工具。 PyTorch官网安装教程&#xff08;可根据系统情况选择不同版本&#xf…

借助IEDA ,Git版本管理工具快速入门

01 引言 一直使用SVN作为版本管理工具&#xff0c;直到公司新来的一批同事&#xff0c;看到我们使用的SVN都纷纷吐槽&#xff0c;什么年代了&#xff0c;还使用SVN。聊下来&#xff0c;才知道人家公司早早就将SVN切成了Git工具&#xff0c;并吐槽SVN的各种弊端。 既然新的技术…

三维空间,毫秒即达:RTMP|RTSP播放器在Unity中的落地实现

有人问我&#xff1a;在 Unity 里做超低延迟的直播播放&#xff0c;是什么感觉&#xff1f; 我说&#xff0c;是把一帧帧流动的时间&#xff0c;嵌进一个三维的空间里。 它不属于现在&#xff0c;也不属于过去。 它属于“实时”——属于那一秒内刚刚发生&#xff0c;却已被你看…

ubuntu 搭建FTP服务,接收部标机历史音视频上报服务器

1.安装vsftpd 1.1.安装命令 sudo apt update sudo apt install vsftpd 1.2.备份原始配置文件 sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.bak 1.3.配置 vsftpd 编辑配置文件 /etc/vsftpd.conf&#xff1a; sudo vim /etc/vsftpd.conf 将以下参数修改为对应值&#xff…

一、内存调优

一、内存调优 什么是内存泄漏 监控Java内存的常用工具 内存泄露的常见场景 内存泄露的解决方案 内存泄露与内存溢出的区别 内存泄露&#xff1a;在Java中如果不再使用一个对象&#xff0c;但是该对象依然在GC ROOT的引用链上&#xff0c;这个对象就不会被垃圾回收器回收&…

Java的Filter与Spring的Interceptor的比较

一、技术规范与框架依赖 维度FilterInterceptor所属规范Servlet 规范&#xff08;Java EE 标准组件&#xff09;Spring MVC 框架组件&#xff08;非 Java EE 标准&#xff09;框架依赖不依赖 Spring&#xff0c;仅需 Servlet 容器&#xff08;如 Tomcat&#xff09;依赖 Sprin…

WPF···

设置启动页 默认最后一个窗口关闭,程序退出,可以设置 修改窗体的icon图标 修改项目exe图标 双击项目名会看到代码 其他 在A窗体点击按钮打开B窗体,在B窗体设置WindowStartupLocation=“CenterOwner” 在A窗体的代码设置 B.Owner = this; B.Show(); B窗体生成在A窗体中间…

微服务架构中的多进程通信--内存池、共享内存、socket

目录 1 引言 2 整体架构简介 3 疑问 3.1 我们的共享内存消息机制是用的posix还是system V 3.2 rmmt中&#xff0c;不同线程之间的比如访问同一个内存&#xff0c;用的什么锁控制的 3.3 疑问&#xff1a;假如一个进程发送给了另外两个进程&#xff0c;然后另外两个进程都同…

电脑中所有word文件图标变白怎么恢复

电脑中的word文件图标变白&#xff0c;如下图所示&#xff1a; 解决方法&#xff1a; 1.winR-->在弹出的运行窗口中输入“regedit”(如下图所示)&#xff0c;点击确定&#xff1a; 2.按照路径“计算机\HKEY_CLASSES_ROOT\Word.Document.12\DefaultIcon”去找到“&#xff0…

RK3568 OH5.1 源码编译及问题

安装编译器和二进制工具 在源码根目录下执行prebuilts脚本&#xff0c;安装编译器及二进制工具。 bash build/prebuilts_download.sh在源码根目录执行如下指令安装hb编译工具&#xff1a; python3 -m pip install --user build/hb使用build.sh脚本编译源码 进入源码根目录&…

Qt5、C++11 获取wifi列表与wifi连接

一、获取wifi列表 .h 文件内容 #include <QWidget> #include <QVBoxLayout> #include <QPushButton> #include <QCheckBox> #include <QListWidget>class Setting : public QWidget {Q_OBJECT public:explicit Setting(QWidget *parent nul…

【KWDB 2025 创作者计划】_从部署开始了解KWDB

一、概述 KaiwuDB 是一款面向 AIoT 场景的分布式、多模融合、支持原生 AI 的数据库产品&#xff0c;支持同一实例同时建立时序库和关系库并融合处理多模数据&#xff0c;具备时序数据高效处理能力&#xff0c;具有稳定安全、高可用、易运维等特点。面向工业物联网、数字能源、…

高等数学-微分

一、一元函数&#xff1a; 在实际应用中&#xff0c;经常需要近似计算函数yf(x)的增量Δyf(x)-f(x0)f(x0Δx)-f(x0),其中一种近似称为函数的微分。 定义&#xff1a;若函数yf(x)在点x0处的增量Δy可表达为自变量增量Δx的线性函数AΔx和Δx的高阶无穷小量之和&#xff0c;即Δ…

有没有开源的企业网盘,是否适合企业使用?

开源选项丰富、灵活定制能力强、需要额外运维投入、适合特定场景但不一定适合所有企业&#xff0c;是开源企业网盘的主要特征。从表面看&#xff0c;开源网盘往往具有免费或低成本优势&#xff0c;但企业要投入一定的人力与技术资源来完成安装、维护与升级&#xff0c;从而保障…