您的位置:首页 > 数据库

数据库连接池简单连接

2015-07-03 10:22 288 查看
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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: