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文件配置
<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-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方法来进行测试