百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

JMeter测试关系数据库:JDBC连接

ccwgpt 2024-12-20 11:33 56 浏览 0 评论

JDBC介绍

JDBC(Java DataBase Connectivity,Java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。

JDBC驱动类型及原理

使用JDBC连接操作数据库步骤

总共有7个步骤:

1.加载JDBC驱动程序

在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机)。

通过java.lang.Class类的静态方法forName(String className)实现。

2.配置JDBC URL

格式为:

协议:子协议:数据源标识

● 协议: 在JDBC中始终为jdbc

● 子协议: 桥连接的驱动程序或是数据库管理系统名称,比如mysql数据源标识: 数据服务器主机名,端口以及数据库名,还可以附带连接参数比如,

jdbc:mysql://192.168.126.128:3306/ecshop?

useUnicode=true&characterEncoding=gbk

3.创建数据库连接

要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,该对象就代表一个数据库的连接。

使用DriverManager的getConnection(String url,String username,String password)方法传入指定的欲连接的数据库的路径,数据库的用户名和密码来获得。

4.创建Statement

要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3种类型:

a.执行静态SQL语句。通常通过Statement实例实现。

b.执行动态SQL语句。通常通过PreparedStatement实例实现。

c.执行数据库存储过程。通常通过CallableStatement实例实现。

5.执行SQL

Statement接口提供了三种执行SQL语句的方法:

a.ResultSet executeQuery(String sqlString),执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象

b.int executeUpdate(String sqlString),用于执行DML,DDL语句

c.boolean execute(String sqlString),用于执行返回多个结果集,多个更新计数或二者组合的语句。

6.处理结果

两种情况:

a.执行更新返回的是本次操作影响到的记录数

b.执行查询返回的结果是一个ResultSet对象

ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些行中数据的访问

7.关闭JDBC对象

操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声明顺序相反:

a.关闭记录集

b.关闭声明

c.关闭连接对象

JDBC Connection Confifiguration配置

Variable Name Bound to Pool:

Variable Name for created pool:

连接绑定的变量名,JMeter可以使用多个连接,每个连接绑定到不同的变量;通过引用不同的绑定变量使用不同的数据库连接。

绑定变量名应与JDBC Request的引用连接的变量名保持一致。

Connection Pool Confifiguration:

1.Max Number of Connections:

该数据库连接池的最大连接数,一般可设置为0,意思是每个线程都使用单独的数据库连接,线程之间数据库连接不共享

2.Max Wait(ms):

超时时间。连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。如果在尝试检索连接池中连接的过程中超过时限,则连接池会抛出错误。

3.Time Between Eviction Runs(ms):

空闲连接回收的时间间隔。如果当前连接池中某个连接的空闲时间大于设置的时间(默认为6000ms)后仍然没有使用,则该连接会被回收关闭。

4.Auto Commit:

连接是否自动提交SQL语句。True自动提交;False手动提交。

5.Transaction isolation:

设置事务的隔离级别。JDBC定义了五种事务隔离级别:

1).TRANSACTION_NONE 不支持事务

2).TRANSACTION_READ_UNCOMMITTED 读未提交。允许脏读,不可重复读和幻读

3).TRANSACTION_READ_COMMITTED 读已提交。禁止脏读,但允许不可重复读和幻读

4).TRANSACTION_REPEATABLE_READ 重复读。禁止脏读和不可重复读,允许幻读

5).TRANSACTION_SERIALIZABLE 串行化。禁止脏读,不可重复读和幻读

6).DEFAULT 使用数据库默认的隔离方式

● 脏读(dirty read):一个事务读取了另一个事务尚未提交的数据

● 不可重复读(Non-Repeatable Reads):一个事务的操作导致另一个事务前后两次读取到不同的数据

● 幻读(Phantom Reads):一个事务的操作导致另一个事务前后两次查询的结果数据量不同

Connection Validation by Pool :

这是JMeter用来检验数据库连接是否有效的一种机制,若超过5秒未使用,则会用Validation Query去测试这个连接是否有效。

1.Test While Idle:

当连接空闲时,是否使用Validation Query去测试连接

2.Soft Min Evictable Idle Time(ms):

连接在连接池中闲置的最小时间,超出此闲置时间连接才会被回收。默认值为5000ms。

3.Validation Query:

用于确定数据库是否仍在响应的简单查询语句。

● hsqldb选择:select 1 from INFORMATION_SCHEMA.SYSTEM_USERS

● Oracle选择:select 1 from dual

● DB2选择:select 1 from sysibm.sysdummy1

● MySQL/SQL Server/PostgreSQL/Ingres/Derby/H2选择:select 1

● Firebird选择: select 1 from rdb$database

Database Connection Confifiguration:

1.Database URL:

JDBC数据库的连接字符串

比如:

jdbc:mysql://localhost:3306/dbname

2.JDBC Driver class:

数据库JDBC驱动类名

MySQL选择:com.mysql.jdbc.Driver

HSQLDB选择:org.hsqldb.jdbc.JDBCDriver

Oracle选择:oracle.jdbc.OracleDriver

DB2选择:com.ibm.db2.jcc.DB2Driver

...

3.Username:

数据库用户名

4.password:

数据库密码

5.Connection Properties

数据库连接属性,多个连接属性之间用“&”连接,为JMeter5.2.1新增配置项。

比如:

useUnicode=true&characterEncoding=utf8&allowMultiQueries=true

相关推荐

FastUI:用Python构建高性能React应用,告别JavaScript

在现代Web开发中,前后端分离已经成为主流趋势。然而,前端开发往往需要深入掌握JavaScript和各种框架,这对于许多Python开发者来说是一个不小的挑战。今天,我们要介绍一个革命性的UI框架——...

Python + Flet 开发网站的最佳数据库模块组合

对于使用Python和Flet开发网站并需要数据库支持的应用,以下是推荐的模块组合方案。方案一:SQLite+SQLAlchemy(推荐轻量级方案)**适用场景**:中小型应用、单用户或...

前端程序员应该往全栈方向发展吗?还是坚守前端?

这是一个非常经典且重要的问题,几乎每一位走到职业生涯十字路口的前端程序员都会思考。它没有一个绝对的“正确答案”,但我们可以从多个维度来分析,帮你找到最适合你的那条路。简单来说,这不是一个“要不要”的...

Python交互仪表盘工具:Panel 进阶学习路线图

Panel作为Python生态系统中最强大的交互式仪表盘工具之一,其学习曲线既平缓又深远。这里我将为您构建一个系统化的进阶学习框架,包含实战项目和关键学习节点。1.现代化Web集成开发1....

PuePy:将Python带入浏览器的革命性框架

在现代网络开发中,JavaScript无疑是主导地位的编程语言。但最近,随着WebAssembly和PyScript的崛起,Python的使用场景逐渐扩展到了前端开发领域。PuePy应运而生,作为一...

不容易!找到一个python的超简易网站搭建神器

作者:清香客来源:Python技术相信很多学习python的酱友们,大部分和我一样是为了提升工作效率,但是在提升自己的工作效率时,也会想着做同样工作的同事能不能也用上自己写的脚本(视工作环境而定)...

PyWebView:用 Python 构建桌面应用的神器

作为一个Python开发者,我一直希望能找到一种简便的方法来构建桌面应用,而不是去学习诸如Electron这种重度依赖JavaScript的技术栈。就在我为桌面应用开发寻找替代方案时,遇到...

Python Django框架中级教程:深入探索Django的核心功能

在Python的Web开发领域中,Django框架以其强大的功能和高效的开发模式占据着重要地位。对于已经掌握了Django基础的开发者来说,进一步深入学习中级知识能让我们开发出更复杂、更强大的Web应...

【Python程序开发系列】使用Flask实现前后端分离(案例)

这是我的第398篇原创文章。一、引言随着web开发的不断发展,前后端分离已成为越来越流行的架构设计。Flask是一个轻量级的Pythonweb框架,非常适合用于构建API,然后配合前端框...

每天一个Python库:Flask超轻量Web框架,灵活高效!

为什么要学Flask?Flask是一个「微型但强大的」Web框架:极简上手,几行代码即可跑起来灵活扩展,想加啥加啥(RESTful、JWT、数据库…)文档齐全,适合入门API开发或快...

Python个人量化投资系统:后台搭建

独立搞量化系统的程序员最烦啥?重复造权限管理的轮子绝对排前三。技术老手用Python+PearAdminFlask两天搭出量化后台,实测开源框架真能省下80%基础工作量。开源后台框架选对,一人项目...

python后端学什么(python后端好找工作吗)

在当今数字化的时代,Python后端开发成为了众多开发者追逐的热门领域。那么,想要在这个领域崭露头角,我们究竟应该学些什么呢?学习Python后端开发需要掌握全栈技术栈,涵盖从基础语法到分布式...

Motia:重新定义后端与智能体整合的未来平台

在AIagent技术飞速发展的今天,我们拥有了诸如Dify、RAGFlow、LangChain等一系列优秀平台。然而,随着场景复杂度增加,开发者正面临一个共同问题:后端越来越碎片化,Agen...

Python数据校验不再难:Pydantic库的工程化实践指南

在FastAPI框架横扫Python后端开发领域的今天,其默认集成的Pydantic库正成为处理数据验证的黄金标准。这个看似简单的库究竟隐藏着哪些让开发者爱不释手的能力?本文将通过真实项目案例,带您解...

Python Flask 建站框架实操教程(flask框架网页)

下面我将带您从零开始构建一个完整的Flask网站,包含用户认证、数据库操作和前端模板等核心功能。##第一部分:基础项目搭建###1.创建项目环境```bash#创建项目目录mkdirfl...

取消回复欢迎 发表评论: