使用连接池技术连接数据库
1.配置tomcat的config文件夹下的context.xml
找到context.xml中的<Context></Context>在其中添加如下代码:
<Context>
<Resource
name="jdbc/news"//指定的Resource 的JNDI名字
auth="Container"//指定管理Resource的Manager,他有两个可选值:Container和Application。Container表示由容器创建 Resource,Appliction表示由Web应用创建和管理Resource
type="javax.sql.DataSource"//指定Resource所属的java类型
maxActive="100"//指定数据连接池中处于活动状态的数据连接的最大数目
maxIdel="30"//指定数据库连接池中处于空闲状态的数据库连接的最大数目,取值为0,表示不受限制
maxWait="1000"//指定数据库连接池中数据连接处于空闲状态的最长时间(以毫秒为单位),超出这一时间将会抛异常
username="root"//指定连接数据库的用户名
password="123456"//指定数据库连接的密码
url="jdbc:mysql://localhost:3306/newsmanagersystem?serverTimezone=GMT&useUnicode=true&characterEncoding=UTF-8"//指定连接数据库的URL
driverClassName="com.mysql.cj.jdbc.Driver"//根据版本写驱动名\;指定连接数据库的JDBC驱动名程序
/>
</Context>
注:在JNDI中的&符号 用&代替
驱动字符串;(mysql)
com.mysql.cj.jdbc.Driver和jdbc:mysql://localhost:3306/newsmanagersystem?serverTimezone=GMT&useUnicode=true&characterEncoding=UTF-8一起用
com.mysql.jdbc.Driver和jdbc:mysql://localhost:3306/newsmanagersystem?useUnicode=true&characterEncoding=UTF-8一起用
2. 在tomcat的lib文件夹下放入connector包
3.配置所建项目WEB-INF下的web.xml
<resource-ref>
<description>new DataSource</description>//对所引用资源的说明
<res-ref-name>jdbc/news</res-ref-name>//指定所引用资源的JNDI名字,与<Resource> 元素中的name属性对应
<res-type>javax.sql.DataSource</res-type>//指定所引用资源的的类名字,与<Resource> 元素中的type属性对应
<res-auth>Container</res-auth>//指定管理所引用资源的Manager,与<Resource> 元素中的auth属性对应
</resource-ref>
4.建立数据库连接
public Connection getConnection(){
try{
//初始化参数
Context ctx = new InitialContext();
//获取与逻辑名相连的数据对象(逻辑名:jdbc/news)
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/news");
try{
Connection conn = ds.getConnection();//建立连接
}catch(SQLException e){
e.printStackTrace();
}
}catch(NamingException e){
e.printStackTrace();
}
return conn;//返回连接
}