为了账号安全,请及时绑定邮箱和手机立即绑定

Tomcat中用JNDI方式加载JDBC DataSource以连接数据库

标签:
MySQL

概括一下,大致分为四步:安装驱动,填充context.xml,填充web.xml,编写程序取得连接。通过一个小DEMO对这种配置方式有了一点了解,以tomcat6.0连接mysql5.0.8数据库为例。

安装驱动

下载与所要连接的数据库版本对应的JDBC驱动程序,加入到应用的CLASSPATH。如果用tomcat部署,tomcat中最好也加上(笔者觉得好像没必要加,可是不加的话会报错……所以还是加了)。应该有办法不加的,若有高手路过,请指点。

填充context.xml

这里就像是做声明样的,把你要连接时的相关属性定义在里面。我的配置如下:

<Context crossContext="true" docBase="E:/workspace/myeclipse-workspace/WebDevDemo/WebRoot" path="/webdemo">

<Resource name="jdbc/EmployeeDB"

auth="Container"

type="javax.sql.DataSource"

username="root"

password=""

driverClassName="com.mysql.jdbc.Driver"

url="jdbc:mysql://localhost:3306/employee"

maxActive="8"

maxIdle="4"/>

</Context>

填充web.xml。我的配置:

<resource-ref>

<res-ref-name>jdbc/EmployeeDB</res-ref-name>

<res-type>javax.sql.DataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

编写程序取得连接。俺的程序:

Context ctx = null;

Context context = null;

DataSource dataSource = null;

Connection conn = null;

PreparedStatement statement = null;

ResultSet rs = null;

try {

ctx = new InitialContext();

context = (Context) ctx.lookup("java:comp/env");

dataSource = (DataSource)context.lookup("jdbc/EmployeeDB");

} catch (NamingException e) {

e.printStackTrace();

}

try {

conn = dataSource.getConnection();//获得连接

//            取数据

statement = conn.prepareStatement(SQL_FIND_ALL_SALARY_RECORDS);

rs = statement.executeQuery();

} catch (SQLException e) {

e.printStackTrace();

}

按照以上的方式就能在tomcat里以配置的形式连接数据库,比我们把所有的连接属性都定义在类里要方便多了。由于公司用的还是5.0版的tomcat,所以笔者也用这个进行了实验,在操作上与6.0有两处不同:

(1)在上面的第一步,加载驱动时。若是5.0版的,驱动的JAR包要放在%CATALINA_HOME%\common\lib下面;若是6.0版的,驱动的JAR包要放在%CATALINA_HOME%\lib下面。

(2)在上面的第二步,声明连接的方式有所不同。5.0版比较复杂点,需要像下面这样配:

 

<Resource name="jdbc/EmployeeDB" auth="Container" type="javax.sql.DataSource"/>

<ResourceParams name="jdbc/EmployeeDB">

<parameter>

<name>username</name>

<value>root</value>

</parameter>

<parameter>

<name>password</name>

<value></value>

</parameter>

<parameter>

<name>driverClassName</name>

<value>com.mysql.jdbc.Driver</value>

</parameter>

<parameter>

<name>url</name>

<value>jdbc:mysql://localhost:3306/employee</value>

</parameter>

<parameter>

<name>maxActive</name>

<value>8</value>

</parameter>

<parameter>

<name>maxIdle</name>

<value>4</value>

</parameter>

</ResourceParams>

</Context>



作者:Java高级技术
链接:https://www.jianshu.com/p/a5c1cb2217ca


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消