【Mybatis从0到1-015】Spring与MyBatis整合原始开发DAO(不推荐使用)

mybatis与Spring整合之后,开发dao的原始方法,不推荐使用,这里仅与之前mybatis独自开发时做简单的对比。【005-mybatis独自使用开发dao】

整合思路

需要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】结果显示


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值