5.
数据源 DataSource 连接数据库
DataSource 接口是 JDBC 2.0 API 中的新增内容,它提供了连接到数据源的另一种方法。使用
DataSource 对象是连接到数据源的首选方法。
该工厂用于提供到此
DataSource 对象表示的物理数据源的连接。作为 DriverManager 设施的替代项,DataSource 对象是获取连接的首选方法。实现 DataSource 接口的对象通常在基于 JavaTM Naming and Directory Interface (JNDI) API 的命名服务中注册。
DataSource 接口由驱动程序供应商实现。共有三种类型的实现:
a) 基本实现 - 生成标准 Connection 对象
b) 连接池实现 - 生成自动参与连接池的 Connection 对象。此实现与中间层连接池管理器一起使用。
c) 分布式事务实现 - 生成一个 Connection 对象,该对象可用于分布式事务,并且几乎始终参与连接池。此实现与中间层事务管理器一起使用,并且几乎始终与连接池管理器一起使用。
DataSource 对象的属性在需要时可以修改。例如,如果将数据源移动到另一个服务器,则可更改与服务器相关的属性。其优点是,因为可以更改数据源的属性,所以任何访问该数据源的代码都无需更改。
一般步骤:
5.1 导入两个类包commons-dbcp和commons-pool(来自apache)
5.2 创建数据源 BasicDataSource ds = new BasicDataSource();
5.3 设置数据库连接池基本信息,如:
数据库驱动,数据库连接协议地址,数据库用户名,密码
数据库最大活动连接,最大空闲连接,是否预编译等等
5.4 激活连接 java.sql.Connection conn = ds.getConnection();
关键代码:
BasicDataSource ds = new BasicDataSource();
ds.setDriverClassName(driverClassName);
ds.setUrl(url);
ds.setUsername(username);
ds.setPassword(password);
/**
* 最大活动连接数
* 同时进行的数据库连接数不超过这个数目
* */
ds.setMaxActive(20);
/**
* 最大空闲连接数
* 当释放数据库连接后,空闲连接数超过这个数目时关闭一些空闲连接
*/
ds.setMaxIdle(8);
/**
* 是否预编译SQL语句
* */
ds.setPoolPreparedStatements(true);
conn = ds.getConnection();
注意: 不支持org.apache.commons.dbcp.BasicDataSource不支持getConnection(String username, String password)方法,该类重写javax.sql.DataSource类中成员方法,方法体直接抛出UnsupportedOperationException,代码如下:
public Connection getConnection(String user, String pass) throws SQLException {
// This method isn't supported by the PoolingDataSource
returned by
// the createDataSource
throw new UnsupportedOperationException("Not supported by BasicDataSource");
// return createDataSource().getConnection(username, password);
分享到:
相关推荐
数据源连接池(DataSource或Connection Pool)是一种管理数据库连接的技术,它预先创建并维护一定数量的数据库连接,当应用需要时可以从池中获取连接,用完后归还,而不是每次操作都创建新的连接。这样可以避免频繁...
- **数据源初始化**(注释掉未实现):尝试使用JNDI查找数据源,如果找到了数据源,则可以通过数据源获取数据库连接。 - **连接初始化**:加载指定的数据库驱动,并使用`DriverManager.getConnection(url, user, ...
1.6 小结 第2章 设计数据库 2.1 数据库设计应考虑的事项 2.1.1 项目规范 2.1.2 设计表 2.1.3 生成发票 2.2 引用完整性 2.2.1 通用完整性规则 2.2.2 特定于数据库的完整性规则 2.3 小结 第3章 SQL基础 ...
1.6 小结 第2章 设计数据库 2.1 数据库设计应考虑的事项 2.1.1 项目规范 2.1.2 设计表 2.1.3 生成发票 2.2 引用完整性 2.2.1 通用完整性规则 2.2.2 特定于数据库的完整性规则 2.3 小结 第3章 SQL基础 ...
1.6 小结 第2章 设计数据库 2.1 数据库设计应考虑的事项 2.1.1 项目规范 2.1.2 设计表 2.1.3 生成发票 2.2 引用完整性 2.2.1 通用完整性规则 2.2.2 特定于数据库的完整性规则 2.3 小结 第3章 SQL基础 ...
1.6 小结 第2章 设计数据库 2.1 数据库设计应考虑的事项 2.1.1 项目规范 2.1.2 设计表 2.1.3 生成发票 2.2 引用完整性 2.2.1 通用完整性规则 2.2.2 特定于数据库的完整性规则 2.3 小结 第3章 SQL基础 ...
Java数据库连接(JDBC) 什么是JDBC JDBC结构 开始起步 使用JDBC 一个简单的范例 对映Java与SQL类型 处理SQL错误 ResultSet与数据库元数据 JDBC中的事务处理 一个JDBC事务范例 ...
这个配置将创建一个名为 `dataSource` 的数据源,并使用 C3P0 连接池。 小结 在本文中,我们详细介绍了如何在 Spring Boot 应用程序中使用 C3P0 数据库连接池。C3P0 提供了高性能、可靠性和可扩展性,解决了数据库...
- `key`:当存在多个数据源时,用于标识数据源的唯一键。 - **示例**: ```xml <data-sources> <data-source type="org.apache.commons.dbcp.BasicDataSource" key="dataSourceA"> <!-- 数据库连接参数配置 -->...
##### 7.3 Jsp连接mysql调用数据源方法 - **7.3.1 对mysql数据库最基本的DB操作**:这部分提供了基本的数据库操作示例,如查询、插入、更新和删除数据。 - **7.3.2 调用对DB操作的方法**:这里讨论了如何封装数据库...
这样,Spring 就可以使用这个数据源来创建一个数据库连接。 2. 由 JNDI 查询的数据源 除了使用 JDBC 驱动程序定义数据源外,我们还可以使用 JNDI 查询来获取数据源。在这种方式中,我们需要在应用程序的配置文件中...
SpringBoot整合Druid数据源是当前流行的开发方式之一,Druid数据源是目前最流行的数据库连接池之一。本篇文章将详细介绍SpringBoot整合Druid数据源的过程,并通过示例代码对大家的学习或者工作具有一定的参考学习...
- **DataSource配置**:配置数据源,用于建立数据库连接。 - **使用JDBCTemplate**:使用Spring的`JdbcTemplate`类来执行SQL语句。 ##### 10.5.2 Hibernate 整合 Spring开发 - **创建项目**:创建一个包含Spring和...
数据源的作用是将数据库连接池暴露给应用程序使用,使得应用程序可以通过数据源获取数据库连接。在WebLogic控制台中,数据源的配置通常在“Services”下的“DataSources”中完成。 #### 3. 部署应用程序 最后,...
你需要指定数据源(dataSource)、Hibernate配置属性以及映射文件的位置。例如: ```xml <property name="dataSource" ref="dataSource" /> <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9...
1.10小结 45 第二章 开发第一个Java应用程序 46 2.1 介绍 46 2.2 手工编写,编译并运行Java程序 46 2.3 使用Eclipse/MyEclipse来编写,编译并运行Java程序 47 2.4小结 50 第三章 Eclipse 的基础概念,配置和使用 51 ...
在Spring框架中,JTA(Java Transaction API)事务管理是一种用于处理分布式事务的高级机制,它允许应用程序在多个数据源之间进行协调的事务操作。本文将详细介绍如何在Spring中使用JTA事务管理,包括通过集成JOTM...
-- 数据源配置 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> ${jdbc.driverClassName}"/> ${jdbc.url}"/> ${jdbc.username}"/> ${jdbc.password}"/> ...
- **获取数据源**:`getDataSource()`方法用于获取数据源对象。 - **资源释放**:`closeResource()`方法用于释放与数据库交互过程中产生的资源,例如连接、Statement等。 - **关闭连接**:`closeConn()`方法用于关闭...