模板化的訪問方式
在直接使用具體的持久化技術時,我們大多需要處理整個流程。Spring為支持的持久化技術分別提供了模板訪問的方式,降低了使用各種持久化技術的難度,可以大幅提高開發效率。
使用模板和回調機制
Spring為各種支持的持久化技術都提供了簡化操作的模板和回調,在回調中編寫具體的數據操作邏輯,使用模板執行數據操作,在Spring中,這是典型的數據操作模式。
JDBCTemplate
HibernateTemplate
SqlMapClientTemplate
如果我們直接使用模板類,一般都需要在DAO中定義一個模板對象并提供數據資源,Spring為每一個持久化技術都提供了支持類,支持類中已經為我們完成這樣的功能。這樣,我們只需要擴展這些支持類就可以直接編寫實際的數據訪問邏輯,沒有絲毫阻隔。
JdbcDaoSupport
HibernateDaoSupport
SqlMapClientDaoSupport
數據源,不管通過何種持久化技術,都必須擁有數據連接,在Spring中,數據連接是通過數據源獲得的,可以直接在Spring容器中配置數據源。
jdbcTemplate
spring提供用于操作JDBC工具類,類似:DBUtils
依賴連接池DataSource(數據源)
環境:
com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar
dbcp
commons pool
spring-jdbc-3.2.0.RELEASE.jar
spring-tx-3.2.0.RELEASE.jar:
A.在程序中直接使用
B.在XML中配置DBCP
"dataSourceId"class="org.apache.commons.dbcp.BasicDataSource">
"driverClassName"value="com.mysql.jdbc.Driver">
"url"value="jdbc:mysql://localhost:3306/hibernate3">
"username"value="root">
"password"value="root">
"jdbcTemplateId"class="org.springframework.jdbc.core.JdbcTemplate">
"dataSource"ref="dataSourceId">
"userDaoId"class="com.dream.dao.UserDao">
"jdbcTemplate"ref="jdbcTemplateId">
Dao層代碼的編寫
配置C3P0
JdbcDaoSupport
編寫dao
public class UserDao extends? JdbcDaoSupport{
public? void update(User user){
String? sql = "update user set username=?,password=? where id =?";
Object[]? args = {user.getUsername(),user.getPassword(),user.getId()};
this.getJdbcTemplate().update(sql,? args);
}
public? List findAll() {
return? this.getJdbcTemplate().query("select * from user",? ParameterizedBeanPropertyRowMapper.newInstance(User.class));
}
}
配置更改
Properties
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/hibernate3
jdbc.user=root
jdbc.password=root
"classpath:"前綴表示src下
在配置文件之后通過${key}獲得內容
-->