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();
时间: 2024-12-24 16:03:33

Spring之DAO模块的相关文章

Spring的DAO模块

Spring的DAO模块提供了对JDBC.Hibernate.JDO等DAO层支持. DAO模块依赖 commons-pool.jar.commons-collections.jar package com.dao; import java.util.ArrayList; import java.util.Date; import java.util.List; import java.util.Map; import org.springframework.jdbc.core.support.

spring的核心模块有哪些?

Spring的七个核心模块,供大家参考,具体内容如下 1.Spring core:核心容器 核心容器提供spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanFactory来产生和管理Bean,它是工厂模式的实现.BeanFactory使用控制反转(IoC)模式将应用的配置和依赖性规范与实际的应用程序代码分开.BeanFactory使用依赖注入的方式提供给组件依赖.主要实现控制反转IoC和依赖注入DI.Bean配置以及加载.

Maven 搭建spring boot多模块项目

Maven 搭建spring boot多模块项目 备注:所有项目都在idea中创建 1.idea创建maven项目 1-1: 删除src,target目录,只保留pom.xml 1-2: 根目录pom.xml可被子模块继承,因此项目只是demo,未考虑太多性能问题,所以将诸多依赖 都写在根级`pom.xml`,子模块只需继承就可以使用. 1-3: 根级pom.xml文件在附录1 1-4: 依赖模块 mybatis spring-boot相关模块 2.创建子模块(module) 2-1: file

Spring--开篇 (spring优缺点、模块组件、各个jar包详解)

Spring--开篇 分类: SSH&EJB2012-11-23 15:25 4369人阅读 评论(13) 收藏 举报 javaJavaJAVAspringSpringwebWebWEB框架 一.  简介 Spring功能日益强大,不断的版本更新中整合进各种技术,几乎成了企业级开发的御用框架,从开发手册来看,包含了以下七大模块: Core包是框架的最基础部分,并提供依赖注入(Dependency Injection)管理Bean容器功能. Context包,构建于Core包上,提供了一种框架式访

一头扎进Spring之---------Spring七大核心模块

Spring七大核心模块 核心容器(Spring Core) 核心容器提供Spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanFactory来产生和管理Bean,它是工厂模式的实现.BeanFactory使用控制反转(IoC)模式将应用的配置和依赖性规范与实际的应用程序代码分开 应用上下文(Spring Context) Spring上下文是一个配置文件,向Spring框架提供上下文信息.Spring上下文包括企业服务,如J

spring的核心模块

核心容器(Spring Core) 核心容器提供Spring框架的基本功能.Spring以bean的方式组织和管理Java应用中的各个组件及其关系.Spring使用BeanFactory来产生和管理Bean,它是工厂模式的实现.BeanFactory使用控制反转(IoC)模式将应用的配置和依赖性规范与实际的应用程序代码分开. 应用上下文(Spring Context) Spring上下文是一个配置文件,向Spring框架提供上下文信息.Spring上下文包括企业服务,如JNDI.EJB.电子邮件

Spring Framework------&gt;version4.3.5.RELAESE-----&gt;Reference Documentation学习心得-----&gt;Spring Framework中的spring web MVC模块

spring framework中的spring web MVC模块 1.概述 spring web mvc是spring框架中的一个模块 spring web mvc实现了web的MVC架构模式,可以被用于开发web网站 spring web mvc 实现web网站的原理,如下图: 2.使用spring web mvc开发web应用的步骤 step1:在自己的工程中引入spring web mvc模块 step2:配置spring web mvc模块 中的DispatcherServlet,告

循环调用spring的dao,数个过后无响应

循环调用spring的dao,数个过后无响应 博客分类: spring daospringssh 最近遇到这么一个问题:前台按钮发送AJax请求到后台,后台是SSH框架.每点击一下按钮就发送一次请求. 点击数次(7次)过后,页面无ajax响应. 在排除前台因素之后,找 到后台代码.写一个Test类. public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationCo

Spring之WEB模块

Spring的WEB模块用于整合Web框架,例如Struts 1.Struts 2.JSF等 整合Struts 1 继承方式 Spring框架提供了ActionSupport类支持Struts 1的Action.继承了ActionSupport后就能获取Spring的BeanFactory,从而获得各种Spring容器内的各种资源 import org.springframework.web.struts.ActionSupport; public class CatAction extends