数据库连接池简单连接

MVC设计模式

模型      -----     Model 视图      -----     View 控制器  -----     Controller

Model层主要是进行业务逻辑处理、访问数据库和封装数据

企业级开发需要稳健和高效的数据访问层,而传统的JDBC已经无法满足需求。于是出现了连接池这项技术。连接池是由容器提供的,用来管理池中连接对象。

使用连接池需要三个步骤

1、编写代码:

<span style="font-size:14px;">		//通过Context、DataSource获取Connection对象
		Context ic = new InitialContext();
		DataSource source = (DataSource)ic.lookup("java:comp/env/jdbc/books");
		Connection connection = source.getConnection();</span>

其中"java:comp/env/jdbc/books"中,java:comp/env为JavaEE默认路径;jdbc/books为DataSource名。

2、在Tomcat的conf/context.xml中配置<Resource .../>标签

<span style="font-size:14px;"><Context>
	<Resource 
		name="jdbc/books"<!--此处的名字要和第一步的DataSource名字相同-->
		type="javax.sql.DataSource"
		maxActive="100"<!--最大可以有100个用户连接数据源-->
		maxIdle="30"<!--如果没有用户连接,会有30个连接等待用户使用-->
		maxWait="5000"<!--假如用户5000毫秒内没有连接数据源,则放弃此连接-->
		username="sa"
		password="sa"
		driverClassName="com.mysql.jdbc.Driver"<!--数据库的驱动-->
		url="jdbc:mysql://localhost:3306/books"<!--数据库的连接地址-->
	/>
</Context></span>

【对于上面的数据库的驱动和连接地址:

MySQL:driverClassName="com.mysql.jdbc.Driver"

url="jdbc:mysql://localhost:3306/数据库名"

SqlServer:driverClassName="com.microsoft.sqlserver.SQLServerDriver"

url="jdbc:sqlserver://localhost:1433;DatabaseName=数据库名"

Oracle:driverClassName="oracle.jdbc.OracleDriver"

url="jdbc:oracle:thin:@localhost:1521:数据库名"

3、把数据库驱动的.jar文件,加入到Tomcat的lib文件中。

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

数据源(DataSource)

javax.sql.DataSource接口负责建立与数据库的连接

从Tomcat的数据源获得连接

把连接保存在连接池中

如何获得DataSource对象

数据源由Tomcat提供,不能在程序中创建实例

使用JNDI获得DataSource引用

什么是JNDI

JNDI(Java Naming Directory Interface,Java命名目录接口)是一组在Java应用中访问命名和目录服务的API

javax.namming.Context接口的lookup()方法

使用JNDI获取连接对象:

<span style="font-size:14px;">import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
public class TitlesBean {
      public List getTitles() {
         try {
              Context ic = new InitialContext();
              DataSource source = 
            		  (DataSource)ic.lookup("java:comp/env/jdbc/books");
              Connection connection = source.getConnection();
              titlesQuery = connection.prepareStatement("SELECT *  FROM titles ");
               ResultSet results = titlesQuery.executeQuery();
               //为BookBean对象的属性赋值,并添加到titlesList中             
          } catch (SQLException exception) {
                 exception.printStackTrace();
         }catch (NamingException namingException)      
                   namingException.printStackTrace();
        }finally{   closeConn();   }
   }   }</span>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏沃趣科技

Oracle数据库性能障碍分析利器:SYSTEMSTATE DUMP介绍

作者 孟庆辉 沃趣科技数据库工程师 当数据库出现严重的性能问题或者hang了的时候,我们非常需要通过systemstate dump来知道进程在做什么,在等待...

3667
来自专栏AILearning

Apache Zeppelin 中 JDBC通用 解释器

概述 JDBC解释器允许您无缝地创建到任何数据源的JDBC连接。 在运行每个语句后,将立即应用插入,更新和升级。 到目前为止,已经通过以下测试: ...

3037
来自专栏Android干货

Android项目实战(二十五):Android studio 混淆+打包+验证是否成功

3337
来自专栏py+selenium

linux 安装weblogic12.1.3.0步骤

需注意:fmw_12.1.3.0.0_wls.jar     需要jdk1.7.0_15以上的版本

7235
来自专栏乐沙弥的世界

cannot set user id: Resource temporarily unavailable

    前阵子,Infra报告无法透过putty以及SecureCRT连接到数据库服务器,提示的错误为Resource temporarily unavaila...

750
来自专栏向治洪

Android 进程回收之LowMemoryKiller原理篇

在前面的文章Android进程保活一文中,对于LowMemoryKiller的概念做了简单的提及。LowMemoryKiller简称低内存杀死机制。简单来说,L...

35910
来自专栏开心的学习之路

Fedora27搭建GPU版TensorFlow

主机:华硕(ASUS)G11飞行堡垒 显卡:GeForce 1070 原操作系统为win10,准备安装Fedora 27,从零开始搭建GPU版TensorF...

3377
来自专栏乐沙弥的世界

配置共享服务器模式

两者完成相同的任务,即处理所有指定的SQL操作。假定从客户端提交一个任意查询(DQL)到数据库服务器不论是专用模式还是共享

2143
来自专栏沃趣科技

ASM 翻译系列第三十六弹:ACFS磁盘组的重平衡操作

原作者:Bane Radulovic 译者: 魏兴华 审核: 魏兴华 DBGeeK社区联合出品 原文链接:http://asmsupportguy....

36011
来自专栏程序员同行者

saltstack 初始化LINUX系统

前面我们已经了解了saltstack的基础功能,现在就可以使用saltstack为初始化新安装的linux系统。

1926

扫码关注云+社区

领取腾讯云代金券