现在的位置: 首页 > 综合 > 正文

Tomcat 数据源配置

2018年04月27日 ⁄ 综合 ⁄ 共 1440字 ⁄ 字号 评论关闭

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方法来进行测试





抱歉!评论已关闭.