数据库连接池简单连接
2015-07-03 10:22
288 查看
MVC设计模式
模型 ----- Model
视图 ----- View
控制器 ----- Controller
Model层主要是进行业务逻辑处理、访问数据库和封装数据
企业级开发需要稳健和高效的数据访问层,而传统的JDBC已经无法满足需求。于是出现了连接池这项技术。连接池是由容器提供的,用来管理池中连接对象。
使用连接池需要三个步骤:
1、编写代码:
其中"java:comp/env/jdbc/books"中,java:comp/env为JavaEE默认路径;jdbc/books为DataSource名。
2、在Tomcat的conf/context.xml中配置<Resource .../>标签
【对于上面的数据库的驱动和连接地址:
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获取连接对象:
模型 ----- 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>
相关文章推荐
- 性能优化之数据库优化
- Oracle系列——开发中奇葩问题你遇到几个(一)
- oracle 增加控制文件的方法
- MSSQLSERVER添加c# clr程序集的使用方法
- Redis学习站点
- SQL查询表中所有字段属性,字段长度,备注信息
- MySql表、字段、库的字符集修改及查看方法
- MySQL按照汉字的拼音排序、按照首字母分类
- Cassandra vs MongoDB vs CouchDB vs Redis vs Riak vs HBase vs Couchbase vs OrientDB vs Aerospike vs N
- oracle中什么情况下用索引?
- C#/Sqlite-单机Window 程序 sqlite 数据库实现
- C#/Sqlite-SQLite PetaPoco django 打造桌面程序
- MySQL导入sql脚本错误:2006 - MySQL server has gone away
- MongoDB初学者的配置环境和基础设施的使用
- 借助 MySQLTuner 优化 MySQL 性能(转载的一篇文章)
- 桌面轻量级数据库的选择:Access、SQLite、自己编写?
- SQLite快速入门指南
- 实战体验几种MySQLCluster方案
- SQL登录器制作
- 2003 - Can't connect to MySQL server on‘localhost' (10061).