dbcp连接池的一些方法
创建连接
// 简写版: Connection conn =null; Statement st =null; conn = DBCP.getConnection(); st=conn.createStatement();
1.批处理 addBatch()
可以将多个操作数据库的字符串集中处理
String sql1="select ..... ";
String sql2="select ..... ";
..............
st.addBatch(sql1);
st.addBatch(sql2);
..............
st.executeBatch(); //集中处理
st.clearBatch();// 最好及时清理,否则字符串仍留在addBatch里面
2.事物管理 setAutoCommit(boolean);
某些逻辑必须在一个是事务完成:通过事务管理可以让多个逻辑在一个事务完成。
事物特性: ACID
Atomicty 原子性:事务必须是原子工作单元,数据的修改要么完全执行,要么全都不执行。
Consistency 一致性: 事务完成时,必须所有数据都保持一致的状态。
Isolation 隔离性 :由并发事务所作修改必须与其他并发事务所作修改隔离。
Durability 持久性: 事务完成后,它对系统的影响是永久性的。
conn.setAutoCommit( false ); //关闭自动提交,默认是true
st.executeUpdate(sql1);
st.executeUpdate(sql2);
conn.commit(); //手动提交,作用是操作sql1和sql2都执行,或者都不执行
3.preparedStatement :预编译的,可以有效防止注入式攻击
String sql="select * from emp_xx where ename = upper(?) and sal > ?";
Connection conn=DBCP.getConnection();
PreparedStatement p=conn.prepareStatement(sql);
p.setString(1, "scott");
p.setDouble(2, 1000.0);
ResultSet rs=p.executeQuery();
4.结果集
@Test public void test8(){ String sql ="select * from emp_xx"; Connection conn=null; ResultSet rs=null; try { conn=DBCP.getConnection(); PreparedStatement ps = conn.prepareStatement(sql); rs=ps.executeQuery(); ResultSetMetaData meta =rs.getMetaData(); //获取元数据集 int number= meta.getColumnCount();//获取结果集里的列的数量 System.out.println(meta.getColumnTypeName(1));//获取某一列的类型 列的序号从1开始数 for (int i = 1; i <=number; i++) { String columName=meta.getColumnName(i);//遍历获取结果集里的所有列名 System.out.println(columName); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
5.可滚动结果集
@Test public void test9(){ String sql ="select ename,sal from emp_xx order by sal"; Connection conn=null; ResultSet rs=null; try { conn=DBCP.getConnection(); //如果要创建可滚动结果集,statement 或者prepareStatement 创建有所不同: // Statement stmt = conn.createStatement(type,concurrney); // PreparedStatement ps = conn.prepareStatement(sql,type,concurrney); /** * 其中 type 取值: * TYPE_FORWARD_ONLY: 默认,只能向下读取 * TYPE_SCROLL_INSENSTIVE : 可滚动,不感知数据变化 * TYPE_SCROLL_SENSTIVE :可滚动,感知数据变化 * 其中 concurrency: * CONCUR_READ_ONLY: 只读,不能更新 * CONCUR_UPDATABLE: 可以更新的结果集 */ Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); rs=stmt.executeQuery(sql); /** * 移动指针的常用方法 : * first :指针移动到第一条 * last :指针移动到最后一条 * beforeFirst: * afterLast: * isFirst: 判断是否指向第一条 * isLast:是否是最后一条 * isbeforeFirst: * isafterLast: * relative :移动到当前指针的相对位置 * next :移动到下一条 * previous:移动到前一条 * absolute:移动到绝对位置 */ //更新结果集数据: rs.absolute(3);// 指针移到第3条记录 rs.updateDouble(2, 2000);//更新第二列数据 变成1555 // rs.updateRow();//更新数据源数据 rs.first(); while(rs.next()){ System.out.print(rs.getString("ename")+" "); System.out.println(rs.getString("sal")); } } catch (SQLException e) { e.printStackTrace(); }finally { if(conn!=null){ try { conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
dbcp连接池的一些方法的更多相关文章
- 采用DBCP连接池技术管理连接
DBCP的使用步骤步骤一:导包,使用第三方的道具,必须导入相应的jar包. 一般需要导入两个jar包: -commons-dbcp-1.x.jar包 -commons-pool-1.x.x.jar包 ...
- DBCP连接池介绍
DBCP连接池介绍 ----------------------------- 目前 DBCP 有两个版本分别是 1.3 和 1.4. DBCP 1.3 版本需要运行于 JDK 1.4-1.5 ,支持 ...
- DBCP连接池原理分析及配置用法
DBCP连接池介绍 ----------------------------- 目前 DBCP 有两个版本分别是 1.3 和 1.4. DBCP 1.3 版本需要运行于 JDK 1.4-1.5 ,支持 ...
- JNDI和在tomcat中配置DBCP连接池 元数据的使用 DBUtils框架的使用 多表操作
1 JNDI和在tomcat中配置DBCP连接池 JNDI(Java Naming and Directory Interface),Java命名和目录接口,它对应于J2SE中的javax.namin ...
- 【转】DBCP连接池原理分析
---------------------------- 目前 DBCP 有两个版本分别是 1.3 和 1.4. DBCP 1.3 版本需要运行于 JDK 1.4-1.5 ,支持 JDBC 3. DB ...
- DBCP连接池的使用
1.新建工程 2.导入commons-dbcp commons-logging commons-pool这三个包 3.创建dbcpconfig.properties的文件 实例如下 #连接设置 dri ...
- 使用c3p0与DBCP连接池,造成的MySql 8小时问题解决方案
转自:http://blog.csdn.net/wangfayinn/article/details/24623575 c3p0数据库连接池mysql8小时 目录(?)[-] 基本问题解决 项目环境 ...
- DBCP 连接池
DBCP数据源 DBCP 是 Apache 软件基金组织下的开源连接池实现 导入maven包: <!-- dbcp连接池 --> <dependency> <groupI ...
- Java学习笔记50(DBCP连接池)
实际开发中,连接数据库是十分消耗资源的操作,但是,我们又需要频繁地连接数据库 这时候,为了提高效率,这里就会采用连接池技术: 连接池地通俗理解: 一个池里面放入很多的连接,需要哪一个取出来用即可,用完 ...
随机推荐
- python 聚类分析 k均值算法
dataSet = [ #数据集 # 1 [0.697, 0.460], # 2 [0.774, 0.376], # 3 [0.634, 0.264], # 4 [0.608, 0.318], # 5 ...
- java.lang.IllegalStateException: Active Spring transaction synchronization or active JTA transaction with specified [javax.transaction.TransactionManager] required
错误信息: java.lang.IllegalStateException: Active Spring transaction synchronization or active JTA trans ...
- NO11 SSH故障排查思路和netstat命令
本章知识相关考试:1.企业场景面试题:Linux系统如何优化?2.企业场景面试题:SSH服务连不上,如何排查?记住回答技巧: 1 ping 2 telnet 客户端ssh工具:SecureCRT,x ...
- 重装系统,新安装IDEA启动项目后,classnotfound:com.mysql.jdbc.Driver
我最后解决是:这个Test connection会自动帮你下载的,但是如果中途一直叫你try again,甚至到后面点这个test connection有弹窗,但是单窗里面的选项你点击后没反应,我是直 ...
- l5213. 玩筹码
这道题本应该很简单的但是我把他复杂化了,所以没有在第一时间里A出来.我们来看看题目 看上去是不是很复杂,思路是有,但是,很难实现.我最开始的时候是认为有三种情况,左边筹码最多,右边筹码最多,中间筹码最 ...
- uni-app解决小程序圆角样式不生效
在使用uni-app实现小程序的时候,设置左图的右圆角不生效,样式也都没有问题,在模拟器上也可以正常现实,手机上样式出现差别,现有以下解决方法: 设置整个圆角,然后左边使用margin-left:-3 ...
- node - 路由的使用
一,服务器文件 app.js .( 要使用路由的文件) const express = require('express') const app = express() const swig = ...
- JavaWeb面试题(转)
1.Tomcat的优化经验 答:去掉对web.xml的监视,把JSP提前编辑成Servlet:有富余物理内存的情况下,加大Tomcat使用的 JVM内存. 2.什么是Servlet? 答:可以从两个方 ...
- 【数据结构】C++语言无锁环形队列的实现
无锁环形队列 1.Ring_Queue在payload前加入一个头,来表示当前节点的状态 2.当前节点的状态包括可以读.可以写.正在读.正在写 3.当读完成后将节点状态改为可以写,当写完成后将节点状态 ...
- 对近期docker学习的总结
Docker 总结 1. 说在前头(Docker命令的格式) docker中的对象分为4个(就目前我所学到的) 镜像 image 容器 container 网络 network 数据卷 volume ...