【Mybatis从0到1-015】Spring与MyBatis整合原始开发DAO(不推荐使用)
2017-08-22 20:26
567 查看
mybatis与Spring整合之后,开发dao的原始方法,不推荐使用,这里仅与之前mybatis独自开发时做简单的对比。【005-mybatis独自使用开发dao】
spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession。(spring和mybatis整合自动完成)
持久层的mapper都需要由spring进行管理。(人工)
jar包:
mybatis3.2.7的jar包
spring3.2.0的jar包
mybatis和spring的整合包:早期ibatis和spring整合是由spring官方提供,mybatis和spring整合由mybatis提供。
现在开始,重新创建工程项目,基于maven,Spring mvc和mybatis。
【1】新建maven工程,name为mybatis_spring,建成后添加Spring mvc框架。同之前一样,创建dao文件夹(包含UserDao.java、UserDaoImpl.java),po文件夹(User),以及resource目录下的sqlMap文件夹及一些文件。
结构如下:
【2】关键代码
UserDao.java代码如下:
UserDaoImpl.java代码如下:
dao接口实现类需要注入SqlSessoinFactory,之前通过构造函数实现,now,通过spring进行注入。
这里spring声明配置方式,配置dao的bean:
sqlMapConfig.xml代码如下:
applicationContext.xml代码如下:
在applicationContext.xml中配置dao。
User.xml代码如下:
【3】测试程序,关键代码如下:
【4】结果显示
整合思路
需要spring通过单例方式管理SqlSessionFactory。(人工)spring和mybatis整合生成代理对象,使用SqlSessionFactory创建SqlSession。(spring和mybatis整合自动完成)
持久层的mapper都需要由spring进行管理。(人工)
整合环境
创建一个新的java工程(接近实际开发的工程结构)jar包:
mybatis3.2.7的jar包
spring3.2.0的jar包
mybatis和spring的整合包:早期ibatis和spring整合是由spring官方提供,mybatis和spring整合由mybatis提供。
现在开始,重新创建工程项目,基于maven,Spring mvc和mybatis。
【1】新建maven工程,name为mybatis_spring,建成后添加Spring mvc框架。同之前一样,创建dao文件夹(包含UserDao.java、UserDaoImpl.java),po文件夹(User),以及resource目录下的sqlMap文件夹及一些文件。
结构如下:
【2】关键代码
UserDao.java代码如下:
public interface UserDao { //根据id查询 User findUserById(int id) throws Exception; }
UserDaoImpl.java代码如下:
dao接口实现类需要注入SqlSessoinFactory,之前通过构造函数实现,now,通过spring进行注入。
这里spring声明配置方式,配置dao的bean:
public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao { public User findUserById(int id) throws Exception { //继承sqlSessionDaoSupport,通过this.getSqlSession()得到sqlSession SqlSession sqlSession = this.getSqlSession(); User user = sqlSession.selectOne("test.findUserById",id); return user; } }
sqlMapConfig.xml代码如下:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 别名定义 --> <typeAliases> <!-- 批量别名定义 指定包名,mybatis自动扫描包中的po类,自动定义别名,别名就是类名(首字母大写或小写都可以)--> <package name="po"/> </typeAliases> <!-- 加载 映射文件 --> <mappers> <!--<package name="mapper"/>--> <mapper resource="sqlMap/User.xml"/> </mappers> </configuration>
applicationContext.xml代码如下:
在applicationContext.xml中配置dao。
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!--加载配置文件--> <context:property-placeholder location="db.properties"/> <!--数据源:使用dbcp--> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driver}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> <property name="maxActive" value="10"/> <property name="maxIdle" value="5"/> </bean> <!--sqlSessionFactory--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!--加载mybatis的配置文件--> <property name="configLocation" value="classpath:SqlMapConfig.xml"/> <!--数据源--> <property name="dataSource" ref="dataSource"/> </bean> <!--原始dao接口--> <bean id="userDao" class="dao.UserDaoImpl"> <property name="sqlSessionFactory" ref="sqlSessionFactory"/> </bean> </beans>
User.xml代码如下:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- namespace命名空间,作用就是对sql进行分类化管理,理解sql隔离 注意:使用mapper代理方法开发,namespace有特殊重要的作用--> <mapper namespace="test"> <!-- 在 映射文件中配置很多sql语句 --> <!-- 需求:通过id查询用户表的记录 --> <!-- 通过 select执行数据库查询 id:标识 映射文件中的 sql 将sql语句封装到mappedStatement对象中,所以将id称为statement的id parameterType:指定输入 参数的类型,这里指定int型 #{}表示一个占位符号 #{id}:其中的id表示 接收输入 的参数,参数名称就是id,如果输入参数是简单类型,#{}中的参数名可以任意,可以value或其它名称 resultType:指定sql输出结果 的所映射的java对象类型,select指定resultType表示将单条记录映射成的java对象。--> <select id="findUserById" parameterType="int" resultType="po.User"> SELECT *FROM USER WHERE id=#{value} </select> </mapper>
【3】测试程序,关键代码如下:
public class UserDaoImplTest { private ApplicationContext applicationContext; //在这里得到Spring容器 @Before public void setUp() throws Exception { applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); } @Test public void findUserById() throws Exception { UserDao userDao = (UserDao) applicationContext.getBean("userDao"); //调用userDao方法 po.User user = userDao.findUserById(1); System.out.println(user); } }
【4】结果显示
相关文章推荐
- 【Mybatis从0到1-016】Spring与MyBatis整合mapper开发DAO(推荐使用)
- mybatis和spring整合后原始dao的开发
- spring+springmvc+mybatis(1)--整合和原始dao开发
- Spring + Mybatis - 原始dao开发整合 与 Mapper代理整合
- (四)mybatis学习之原始Dao开发方式及与spring整合
- Spring + Mybatis - 原始dao开发整合 与 Mapper代理整合
- JavaEE_Mybatis_SpringMVC_框架整合_lesson1_简单的SSM框架搭建_使用原始Dao开发方式进行测试
- mybatis使用 原始dao开发 (自己写dao实现类)
- Spring与Mybatis的整合------原始Dao的整合方式
- Mybatis学习记录(五)--整合spring开发Dao
- mybatis(7)--使用mapper代理开发代替原始的dao开发
- Spring和Mybatis整合(原始dao)
- MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合 一、搭建开发环境 1.1、使用Maven创建Web项目 执行如下命令: mvn archetype:create
- Spring+SpringMVC+MyBatis深入学习及搭建(二)之MyBatis原始Dao开发和mapper代理开发
- 使用mybatis开发原始dao
- Mybatis spring 原始dao整合
- Mybatis和Spring整合(原始Dao)非mapper代理
- Spring+Hibernate DAO 持久层开发, Spring 用 Hibernate 访问数据库的三种方法.推荐使用回调
- Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发