Tomcat 数据源配置

1 概述

   Java SE中提供了JNDI(Java 名称与目录接口),简单可以理解为根据名称找对象的功能。Tomcat提供了DataSource的实现,程序与数据库的连接有几种方式,可以根据在程序中进行连接,并且管理的方式,这种方式的效率是很低的,对于实际的项目中运用较少,一般是利用一些框架,比如说C3P0 ,DBCP等,利用数据库连接池技术,以下是介绍Tomcat 连接数据库的配置

2 配置步骤

     context.xml文件配置

       在META-INF文件下添加文件context.xml配置文件,其示例代码如下

<Context>

    <!-- Default set of monitored resources -->
    <WatchedResource>WEB-INF/web.xml</WatchedResource>
      <Resource 
	       auth="Container"
      	   name="jdbc/name" 
           type="javax.sql.DataSource"  
           driverClassName="com.ibm.db2.jcc.DB2Driver" 
           maxIdle="5" 
           maxWait="-1" 
           username="db2admin" 
           password="123456"
           url="jdbc:db2://192.168.1.10:50000/yourdatabase" 
           maxActive="5"/>     

</Context>
     web.xml文件配置

        在WEB-INF文件下的web.xml文件添加如下节点,其示例代码如下
 <resource-ref>
    <description>DB Connection</description>
    <res-ref-name>jdbc/name</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
  </resource-ref>

3 测试

  在jsp文件或者javaBean中添加如下代码进行测试
public String getTOP(){
		StringBuffer sb=new StringBuffer();
		try {
			Context ctx=new InitialContext();
			DataSource ds=(DataSource) ctx.lookup("java:comp/env/jdbc/name");
			Connection conn=ds.getConnection();
		    Statement st= conn.createStatement(); 
		    ResultSet rs=st.executeQuery("select * from sys_user");
		    
		    while(rs.next()){
		    	System.out.println(rs.getInt(1));
		    	sb.append(rs.getInt(1)+",");
		    }
			
		} catch (NamingException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		return sb.toString();
	}

4 注意事项

    由于DataSource对象是由Tomcat容器进行管理的,所以不能在单独的Java文件中通过main方法来进行测试





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值