连接池实例

在Javaweb开发中连接数据库的方法有JDBC,ODBC数据源,连接池...等。
本人比较喜欢连接池,这里推荐一个实例给大家看看.
首先在tomcat里面找到context.xml
这里以mysql为例子
<Resource name="jdbc/mysqlS2"
auth="Containar"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="root"
password="wei"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/struts2"/>

在上面代码中mysqlS2名字可以任意,但是不能重复.其它连接大家都应该明白这里就不多做解释.
然后在封装一个DButils代码如下:
package com.wei.dang.util;

import java.sql.SQLException;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;

public class DBUtils {
private static DataSource ds = null;
private static Context context;
private static QueryRunner qr;
public static QueryRunner geQueryRunner(){
try {
context = new InitialContext();
ds = (DataSource)context.lookup("java:/comp/env/jdbc/mysqlds");
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
qr = new QueryRunner(ds);
return qr;
}

public static int update(String sql, String[] param) {
int result = 0;
qr = DBUtils.geQueryRunner();
try {
result = qr.update(sql, param);
} catch (SQLException e) {
e.printStackTrace();
}
return result;
}

public static Object query(String sql, String[] param, ResultSetHandler rsh) {
qr = DBUtils.geQueryRunner();
Object result = null;
try {
result = qr.query(sql, param, rsh);
} catch (SQLException e) {
e.printStackTrace();
}
return result;
}
}
上面忘记说了还需要加个DButils的一个jar包.这个包我已经上传了,供大家下载.
补充下面的是oracle请大家动手将上面的改成下面的模式.
import java.sql.SQLException;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;

public class OracleUtil {
private String dataSourceName;
private DataSource ds;

public OracleUtil(String dataSourceName) {
this.dataSourceName = dataSourceName;
}

public OracleUtil() {
}

public void setDataSourceName(String dataSourceName) {
this.dataSourceName = dataSourceName;
}

public void init() {
Context initContext;
try {
initContext = new InitialContext();
ds = (DataSource) initContext.lookup(dataSourceName);
} catch (NamingException e) {
e.printStackTrace();
}
}

public int update(String sql, String[] param) {
int result = 0;
QueryRunner qr = new QueryRunner(ds);
try {
result = qr.update(sql, param);
} catch (SQLException e) {
e.printStackTrace();
}
return result;
}

public Object query(String sql, String[] param, ResultSetHandler rsh) {
QueryRunner qr = new QueryRunner(ds);
Object result = null;
try {
result = qr.query(sql, param, rsh);
} catch (SQLException e) {
e.printStackTrace();
}
return result;
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值