Spring之DAO模块
Spring的DAO模块提供了对JDBC、Hibernate、JDO等DAO层支持
DAO模块依赖于commons-pool.jar、commons-collections.jar
Spring完全抛弃了JDBC API,开发者只需要使用封装好的JdbcTemplate执行SQL语句,然后得到需要的结果
DAO层业务逻辑
public interface IpersonDao{ public String getPersonName(Integer id); public void addPerson(Person person); public int getPersonCount(); public List<Person> listPersons(); } import org.springframework.jdbc.core.support.JdbcDaoSupport; public classPersonDaoImpl extends JdbcDaoSupport implements IPersonDao{ public void initDatabase(){ //初始化数据库 } public String getPersonName(Integer id){ String sql = "select namefrom t_person where id = "+id; return (String)getJdbcTemplate().queryForObject(sql,String.class); } public void addPerson(Person person){ String sql = "insert intot_person (name,sex,age,birthday) values(?,?,?,?) "; Object [] params ={person.getName(),person.getSex(),person.getAge(),person.getBirthday() }; getJdbcTemplate().update(sql, params); } public int getPersonCount(){ String sql = "selectcount(*) from t_person"; returngetJdbcTemplate().queryForInt(sql); } public List<Person> listPersons(){ String sql = "selectid,name,sex,age,birthday from t_person "; List<Map<String,Object>>list= getJdbcTemplate().queryForList(sql); List<Person> personList = new ArrayList<Person> (); for(Map< String,Object > row: list){ Person person = newPerson(); person.setId((Integer)row.get("id")); person.setName((String)row.get("sex")); person.setSex((String)row.get("name")); person.setAge((Integer)row.get("age")); person.setBirthday((Date)row.get("birthday")); personList.add(person); } return personList; } }配置数据源
<bean id="dataSource" class="org.apche.commons.dbcp.BasicDataSurce" destroy-method="close"> <property name="diverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8"/> <property name="username" value="root"/> <property name="password" value="admin"/> </bean> <bean id="personDao" class="com.clf.spring.PersonDaoImpl" depends-on=" dataSource"init-method="initDatabase"> <property name="dataSource" ref="dataSource" /> </bean>返回实体对象
MappingSqlQuery是一个抽象类,开发者需要实现它的mapRow(ResultSet,int)方法实现从ResultSet到Java对象的映射,该方法可以直接返回实体类对象
import org.springframework.jdbc.object.MappingSqlQuery; public class PersonMappingQuery extends MappingSqlQuery{ protected Object mapRow(ResultSet rs,int columnIndex) throws SQLException { Person person = new Person(); person.setId(rs.getInt("id")); person.setName(rs.getString("name")); person.setSex(rs.getString("sex")); person.setAge(rs.getInt("age")); person.setBirthday(rs.getTimstamp("birthday")); return person; } } public List findAllPersons(){ PersonMappingQuery personQuery = newPersonMappingQuery(); personQuery.setDataSource(getDataSource()); personQuery.setSql("select *from t_person where age > ?"); personQuery.declareParameter(newSqlParameter(java.sql.Types.NUMERIC)); personQuery.compile(); return personQuery.execute(new Object [] {newInteger(25) }); }SqlUpdate类
利用SqlUpdate来实现某个功能的模块化
public class UpdateSql extends SqlUpdate{ public UpdateSql(DataSource ds){ setDataSource(ds); setSql("……"); declareParameter(newSqlParameter(Tpyes.NUMERIC)); declareParameter(newSqlParameter(Tpyes.NUMERIC)); compile(); } public int run(int id,int num){ Object [] params = new Object [] { new Integer(id), new Integer(num) }; return update(sql); } }事务管理
<!-- JDBC事务管理--> <bean id="jdbcTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- 为所有的方法配置事务--> <bean id="transactionAttributeSource" class="org.springframework.transaction.interceptor.NameMatchTransactionAttributeSource"> <property name="properties"> <props> <prop key="*">PROPAGATION_REQUIRED</prop><!--事务类型--> </props> </property> </bean> <bean id="transactiionRun" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"> <property name="transactionManager" ref=" jdbcTransactionManager" /> <property name="target" > <bean class="com.clf.spring.TransactionRun"> <property name="personDao" ref="personDao"></property> </bean> </property> <property name="transactionAttributeSource" ref=" transactionAttributeSource" /> </bean>// TransactionRun为用户自定义类 TransactionRun transactionRun = factory.getBean("transactionRun"); transactionRun.run();
Spring之DAO模块的更多相关文章
- Spring【DAO模块】就是这么简单
前言 上一篇Spring博文主要讲解了如何使用Spring来实现AOP编程,本博文主要讲解Spring的DAO模块对JDBC的支持,以及Spring对事务的控制... 对于JDBC而言,我们肯定不会陌 ...
- Spring的DAO模块
Spring的DAO模块提供了对JDBC.Hibernate.JDO等DAO层支持. DAO模块依赖 commons-pool.jar.commons-collections.jar package ...
- Spring DAO模块
Spring的DAO模块提供了对JDBC.Hibernate.Mybatis等DAO层支持,本节介绍DAO模块对JDBC的支持.DAO模块依赖ommons-dbcp.jar.commons-pool. ...
- spring的核心模块有哪些?
Spring的七个核心模块,供大家参考,具体内容如下 1.Spring core:核心容器 核心容器提供spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关 ...
- Spring第七篇【Spring的JDBC模块】
前言 上一篇Spring博文主要讲解了如何使用Spring来实现AOP编程,本博文主要讲解Spring的对JDBC的支持- 对于JDBC而言,我们肯定不会陌生,我们在初学的时候肯定写过非常非常多的JD ...
- Spring【AOP模块】就是这么简单
前言 到目前为止,已经简单学习了Spring的Core模块.....于是我们就开启了Spring的AOP模块了...在讲解AOP模块之前,首先我们来讲解一下cglib代理.以及怎么手动实现AOP编程 ...
- Maven 搭建spring boot多模块项目(附源码),亲测可以,感谢原创
原创地址:https://segmentfault.com/a/1190000005020589 我的DEMO码云地址,持续添加新功能: https://gitee.com/itbase/Spring ...
- 1.Spring——七大主要模块
Spring有七大功能模块,分别是Spring Core,AOP,ORM,DAO,MVC,WEB,Content. 下面分别简单介绍: 1.Spring Core Core模块是Spring的核心类库 ...
- 一头扎进Spring之---------Spring七大核心模块
Spring七大核心模块 核心容器(Spring Core) 核心容器提供Spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanF ...
随机推荐
- 走在spring的路上。。。。
一些spring的概念理解: 1.为什么需要spring? spring与我们平时用的工厂模式最大的差别在于,工厂模式设计还需要单独去建一个工厂类并去维护它, 而spring可只通过配置文件便可创建并 ...
- [LeetCode] Reach a Number 达到一个数字
You are standing at position 0 on an infinite number line. There is a goal at position target. On ea ...
- Spring MVC 知识点记忆
1.Dao 用的 @Repository 2.Handler 用的 @Controller 3. @Autowired 消除了对get set方法 4. @RequestMapping(value= ...
- Python网络爬虫笔记(五):下载、分析京东P20销售数据
(一) 分析网页 下载下面这个链接的销售数据 https://item.jd.com/6733026.html#comment 1. 翻页的时候,谷歌F12的Network页签可以看到下面 ...
- [HAOI2016]找相同字符
题目描述 给定两个字符串,求出在两个字符串中各取出一个子串使得这两个子串相同的方案数.两个方案不同当且仅当这两个子串中有一个位置不同. 输入输出格式 输入格式: 两行,两个字符串s1,s2,长度分别为 ...
- Go学习——defer、panic
defer: 延迟到ret之前,通常用于IO的关闭 or 错误处理. 在延迟出现的异常可以被后面的捕捉,但是只有最后一个. defer可以多次,这样形成一个defer栈,后defer的语句在函数返回时 ...
- ●BZOJ 3270 博物馆
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3270题解: 期望DP,高斯消元 本来是定义的关于概率的dp, 但是发现这样定义有很多解释不通 ...
- 51 nod 1610 路径计数(Moblus+dp)
1610 路径计数 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 路径上所有边权的最大公约数定义为一条路径的值. 给定一个有向无环图.T次修改操作,每次修改一 ...
- bzoj 2594: [Wc2006]水管局长数据加强版
Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一 ...
- bzoj省选十连测推广赛
A.普通计算姬 题意:给丁一棵树,每个点有一个权值,用sum(x)表示以x为根的子树的权值和,要求支持两种操作: 1 u v :修改点u的权值为v. 2 l r : 求∑sum[i] l&l ...