一、JDBC Connection Configuration

1、Variable Name Bound to Pool-Variable Name:连接池名称, JDBC Request通过此名称来获取连接池中的连接;

2、Max Number of Connections:连接池的最大连接数.Pool TimeOut:连接超时设置。

3、Idle CleanUp Interaval:空闲连接清理时间间隔Auto Commit:事务是否自动提交选项,。

4、Transaction Isolation: JDBC事务控制选项

(1)原子性(atomicity):事务是数据库的逻辑工作单位,对于其数据修改,要么全部执行,要么全部不执行。

(2)一致性(consistency):事务在完成时,必须是所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。

(3)隔离性(isolation):一个事务的执行不能被其他事务所影响。

(4)持久性(durability):一个事务一旦提交,事物的操作便永久性地保存在数据库中。

  即使此时再执行回滚操作也不能撤消所做的更改。为了保证维护事务的ACID属性,就产生了锁这种机制,用来做事务隔离,隔离级别有几种呢,就是我们在Transaction Isolation下拉列表中看到的。

  TRANSACTION NONE:不支持事务, TRANSACTIONNONE=0

  TRANSACTION READ UNCOMMITED:允许脏读、不可重复读和幻读。TRANSACTION READ UNCOMMITTED =1

  TRANSACTION READ COMMITTED:禁止脏读,但允许不可重复读和幻读。TRANSA CTION READ COMMITTED 2

  TRANSACTION REPEATABLE READ:禁止脏读和不可重复读,允许幻读。TRANSACTION REPEATABLE READ=4

  TRANSACTION SERIALIZABLE:禁止脏读、不可重复读和幻读, TRANSACTIONSERIALIZABLE=8

  另外还有一个选项DEFAULT,这是JMeter加上去的,默认值是-1,其实是TRANSACTION READ COMMITTED,即禁止脏读,但允许不可重复读和幻读。上面提到了脏读,下面来解释一下脏读。

  脏读:一个事务读取了另外一个事务未提交的数据。

  不可重复:读取一个事务再次读取之前的数据时,这个数据已经被另外一个事务修改。

  幻读:一个事务重新执行一个查询,返回的记录包含了其他事务提交的新记录。

5、Keep-Alive:是否保持与数据库的连接。

6、Max Connection age:连接的生存时间,超过这个时间的连接将由连接池自动断开丢弃。当然正在使用的连接不会马上断开,而是等待它close再断开,配置为0的时候则不会对连接的生存时间进行限制,单位毫秒。

7、Validation Query: 验证SQL语法。

8、Database URL: JDBC连接字符串,读者一定会问,我怎么知道这个连接字符的格式?JDBC连接字符的格式是固定的

MySQL:

  Driver="com.mysql.jdbc. Driver";

  URL="jdbc:mysql://localhost: (端口}/(数据库名)";

Oracle (用thin模式) :

  Driver="oracle.jdbc.driver.OracleDriver" ;

  URL="jdbc:oracle:thin: @loaclhost: (端口): |SIDI";

Microsoft sgL Server

  Driver="com.microsoft.sqlserver.jdbc.sQLServerDriver" ;

  URL="jdbc:microsoft: sqlserver://localhost: :(端口); DatabaseName= {数据库名}";

Sysbase:

  Driver="com.sybase.jdbc.SybDriver";

  URL="jdbc:Sysbase:// localhost: (端口} /[数据库名)";

Postgresql:

  Driver="org.postgresql.Driver';

  URL="jdbc:postgresql://localhost/db name";

DB2:

  Driver="com.ibm.db2.jdbc.app. DB2 . Driver" ; //装有DB2客户端4

  Driver="com.ibm.db2.jdbc.net. DB2. Driver";//未装DB2客户端

  URL="jdbc: db2://1ocalhost: (端口}/(数据库名}" ;

JDBC-ODBC:

  Driver="sun.jdbc.odbc. JdbcodbcDriver";

  URL="jdbc:odbc: (数据源名}" ;

  各数据库的驱动下载网址如下,将下载的驱动包放置%jmeter_home%\lib目录下。

    mySQL:https://dev.mysql.com/downloads/connector/

    IBM DB2:http://www-01.ibm.com/support/docview.wss?uid=swg21363866

    Oracle:http://www.oracle.com/technetwork/database/features/jdbc/jdbc-drivers-12c-download-1958347.html

    SQL Server:https://www.microsoft.com/en-us/download/details.aspx?id=55539

    PostgreSQL:https://jdbc.postgresql.org/download.html

    Microsoft Access:https://www.easysoft.com/products/data_access/jdbc-access-gateway/index.html#section=tab-1

9、IDBC Driver class:驱动类名,上面的Driver对应的内容即是。

10、Username:连接数据库的用户名。

11、Password:连接数据库的密码。

------------------------------------------------------------------------------------------------------------------------

二、JDBC Request

1、Variable Name:即是我们在JDBC ConnectionConfiguration 中i的Variable Name。

2、JDBCRequest通过这个名称来获取连接池上下文。

3、Quегу Туре: 可以看到 Query Type有很多,那么这些种类用什么作用,用在哪些场景呢?

  Select Statement:当然是咱们在需要执行查询语句的时候用到。

  pdate Statement:执行更新操作的时候用到,包括插入与修改。

  Callable Statemen:对应JDBC规范中的CallableStatement对象,它为所有的DBMS提供了一种以标准形式调用存储过程的方法,白话就是可以调用存储过程,也就是可以有入参,有占位符,后面实例详述。Prepared Select Statement:预编译查询语句,大家应该听说过绑定变量这个i,咱们在Oracle中为了减少数据库在SQL上的硬编译资源消耗,提倡大家用绑定变量,这样相同的SQL只会被编译一次。上面的Callable Statement是对Prepared Select Statement的扩展。

  Prepared Update Statement:只是把上面的Select换成了Update,意义相同。

  Comnit:当前连接状态中的内容提交。

  Rollback:当前连接状态中的内容回滚。

  AutoCommit (false):指明不需要自动提交。

4、Parameter values: 参数值,用来参数化Sql Query 中的Sql语句。

5、Parameter types: 上面参数值对应的参数。

6、Variable names: SQL执行后得到的红在联 个数据集,我们可以把它保存到变量中来,供后面的元件调用。

7、Result variable name:上面Variable names中的变量是个数与列数对应的, Result Variable Name是把整个结果存在一个数组中。

8、Query timeout:定义查询超时时间。

-------------------------------------------------------------------------------------------------------------

三、JDBC Request实例。

1. Prepared Select Statement在JDBC Request中可以定义入参,入参有两种方式。

  第一种${}引入变量。

  第二种?占位符填充,如Dutyld=? , ?的内容由Parameter Values来填充,多个变量值对应多个占位符,按从左到右的先后顺序对应。

2. Select Statement:执行查询语句,不可以用占位符来做参数化,但可以由${}来引入变量。

3. Update Statement:执行更新操作,不可以用占位符来做参数化,但可以由${}来引入变量,要注意,如果是字符变量记得要加上引号。另外,它也支持Insert操作,比如insert into t user(id,userName,password,realName) values5,'smith',1234',smith').

4. Callable Statement:支持占位符来做参数化,也可以由${}来引入变量。

5. Prepared Select Statement:与Select Statement区别有两点,一是效率上的区别,长时间执行时效率更好;二是参数化的区别,支持占位符,示例在此略过。

6. Prepared Update Statement:与Update Statement的区别同Select Statement与Prepared Select Statement的区别。一是效率上的区别,长时间执行时效率更好;二是参数化的区别,支持占位符。

7. Commit :SQL Query中的SQL执行完成后将马上提交,使用这个选项时JDBC Connection Configuration中的Auto Commit选项为False。

8. Rollback用Commit相同的例子,下面这条SQL是插入数据,如果选择Rollback,那么数据将不会插入数据库。

9. AutoCommit (false如果在JDBC Connection Configuration中的Auto Commit选项为True,现在这种情况下将会覆盖前面的设置,图中的插入操作将不会把数据插入到数据库。

最新文章

  1. Asp.net使用代码修改配置文件的节点值
  2. Git工作流指南:Pull Request工作流
  3. python3爬虫 url管理器
  4. LightSpeed 的Left Join Bug解决方案
  5. Git的status命令
  6. Siverlight网页应用程序中WCF通信注意事项
  7. POJ 3581 Sequence(后缀数组)
  8. 多机同步管理hexo博客
  9. centos备份多个数据库
  10. WEB前端开发记录PS常见操作
  11. FindVisualChild
  12. VS2010显示行号
  13. 怎样让两个DIV在同一水平线上面显示
  14. Java学习笔记42(序列化流)
  15. django使用session缓存Redis
  16. Spring 集成Junit单元测试
  17. Git学习系列之Windows上安装Git之后的一些配置(图文详解)
  18. vs2013中,自定义mvc 添加视图脚手架
  19. 决策树与树集成模型(bootstrap, 决策树(信息熵,信息增益, 信息增益率, 基尼系数),回归树, Bagging, 随机森林, Boosting, Adaboost, GBDT, XGboost)
  20. 一个简单的Linux启动jar包的shell脚本

热门文章

  1. tensorflow 根据节点名称获取节点
  2. Percona XtraDB Cluster
  3. java实现跳跃表
  4. BIO与NIO、AIO的区别(这个容易理解)
  5. mac 上位Idea 配置Project SDK
  6. Dicom图像解析
  7. 检测锁及死锁详细信息,及sql语句
  8. Go语言封装Http协议GET和POST请求
  9. 【Mysql】可视化工具
  10. 最新版本Bootstrap样式很奇怪(4.1版本)