分享
 
 
 

利用WebLogic的POOL连接数据库

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

以往用Java存取数据库都是直接用JDBC连接数据库;

一般的,每个数据库客户端应用程序都要打开一个或一个以上的数据库连接,而在weblogic下我们可以利用weblogic提供的POOL来存取数据库,使每个数据库客户端共同分享一个或一个以上的数据库连接,从而可以提高程序的执行效率和减轻数据库服务器的负担。

这篇文章主要讨论的是服务器的配置和代码的实现,在这里在下不想讨论太多POOL的概念和特点,至于POOL的概念及原理,我建议大家看看一篇题为“用连接池提高Servlet访问数据库的效率”的资料,作者是好兵。

本文以Weblogic 5.1+mysql 为例向大家介绍weblogic提供的POOL,我分别写了两个 servlet 作为对照的例子,一个是用 mysql 提供的JDBC来直接存取MYSQL,另一个是weblogic提供的POOL来存取数据库。

首先请看用 mysql 提供的JDBC来直接存取MYSQL的代码:

myjdbc.java

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

import java.io.*;

import java.sql.*;

import weblogic.db.jdbc.*;

import java.util.Properties;

import javax.servlet.*;

import javax.servlet.http.*;

public class myjdbc extends HttpServlet {

public void service(HttpServletRequest req, HttpServletResponse res)

throws IOException

{

res.setContentType("text/Html");

PrintWriter out = res.getWriter();

out.println("<html<head<titleHello World!</title</head");

out.println("<body<h1TEST JDBC!</h1<pre");

Connection Conn = null;

try {

//========================================

Class.forName("org.gjt.mm.mysql.Driver").newInstance();

Conn = DriverManager.getConnection("jdbc:mysql://localhost/zjws?user=zjxyz&passWord=xyz");

//========================================

Statement Stmt = Conn.createStatement();

ResultSet RS = Stmt.executeQuery("SELECT * from users");

while (RS.next()) {

out.println(RS.getString("userid")+"\t"

+RS.getString("passwd")

+"\t"+RS.getString("name"));

}

RS.close();

Stmt.close();

Conn.close();

}catch (Exception E) {

System.err.println("Unable to load driver.");

E.printStackTrace();

}

out.println("</pre</body</html");

}

}

上面的代码功能是把mysql 的 zjws数据库里面 users 表列出来,我把装入JDBC驱动的语句做了标记下面是利用POOL读取数据库,装入JDBC驱动的语句我也做了标记,请仔细比较。

首先是要配置好服务器,在weblogic.properties加入

#======================================

weblogic.jdbc.connectionPool.mysqlPool1=url=jdbc:mysql://localhost/zjws?user=zjxyz,driver=org.gjt.mm.mysql.Driver,loginDelaySecs=1,initialCapacity=4,maxCapacity=10,&nbs

p; capacityIncrement=2,allowShrinking=true,shrinkPeriodMins=15,refreshMinutes=10,allow=guest,props=user=zjxyz;password=xyz;server=zjxyz

#=====================================================

把mysql 的JDBC驱动放在 /weblogic/myserver/serverclasses/ 目录下,不知为何,我把jar包把放在其目录下,把路径加入 classpath 中,结果启动时说找不到class,所以我只好解开的org目录及其里面的文件放进去,结果可以了。

mysql一定要比weblogic先启动,因为weblogic在启动时要创建POOL。

mysqlpool.java

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

import java.io.*;

import java.sql.*;

import weblogic.db.jdbc.*;

import java.util.Properties;

import javax.servlet.*;

import javax.servlet.http.*;

public class mysqlpool extends HttpServlet {

public void service(HttpServletRequest req, HttpServletResponse res)

throws IOException

{

res.setContentType("text/html");

PrintWriter out = res.getWriter();

out.println("<html<head<titleHello World!</title</head");

out.println("<body<h1TEST Weblogic Pool!</h1<pre");

Connection Conn = null;

try {

//=================================================================================

Properties props =new Properties();

props.setProperty("user","system");

props.setProperty("password","zjxyzken");

Driver myDriver =

(Driver) Class.forName("weblogic.jdbc.pool.Driver").newInstance();

Conn =myDriver.connect("jdbc:weblogic:pool:mysqlPool1",props);

//=================================================================================

Statement Stmt = Conn.createStatement();

ResultSet RS = Stmt.executeQuery("SELECT * from users");

while (RS.next()) {

out.println(RS.getString("userid")+"\t"

+RS.getString("passwd")

+"\t"+RS.getString("name"));

}

RS.close();

Stmt.close();

Conn.close();

}catch (Exception E) {

System.err.println("Unable to load driver.");

E.printStackTrace();

}

out.println("</pre</body</html");

}

}

经过阅读源代码,我们可以发现,作为程序员某定程度上根本不需要理会服务器装的是什么SQL数据库,只需连接到weblogic创建提供的POOL就可以了,这样一来除了可以提高效率外还令到代码的可重用性大大提高。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有