idea中使用JNDI连接池连接数据库

使用连接池技术连接数据库

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&amp;useUnicode=true&amp;characterEncoding=UTF-8"//指定连接数据库的URL
		driverClassName="com.mysql.cj.jdbc.Driver"//根据版本写驱动名\;指定连接数据库的JDBC驱动名程序
	/>
</Context>

注:在JNDI中的&符号 用&amp;代替
驱动字符串;(mysql)
com.mysql.cj.jdbc.Driver和jdbc:mysql://localhost:3306/newsmanagersystem?serverTimezone=GMT&amp;useUnicode=true&amp;characterEncoding=UTF-8一起用
com.mysql.jdbc.Driver和jdbc:mysql://localhost:3306/newsmanagersystem?useUnicode=true&amp;characterEncoding=UTF-8一起用

2. 在tomcat的lib文件夹下放入connector包

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;//返回连接
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

师兄白泽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值