ssm-spring集成mybatis

ssm-spring集成mybatis

MyBatis-Spring简介

MyBatis-Spring是一个依赖库,可以无缝的将MyBatis整合到Spring中。该库可以让MyBatis参与到Spring事务管理中,可以负责mapper和SqlSession的创建和注入, 可以将MyBatis中的异常转换为Spring的DataAccessException。最终让你构建的工程代码脱离MyBatis,Spring和MyBatis-Spring的依赖。

快速开始

  1. 导入依赖:
  2. 首先在pom.xml文件中,导入以下配置:
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>2.0.6</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>5.3.10</version>
    </dependency>
  3. 配置数据源:
  4. <!--配置数据源,可以是实现了javax.sql.DataSource接口的任意数据源,这里使用MysqlDataSource-->
    <bean id="dataSource" class="com.mysql.cj.jdbc.MysqlDataSource">
        <property name="url" value="jdbc:mysql://xxx"/>
        <property name="user" value="数据库用户名"/>
        <property name="password" value="数据库密码"/>
    </bean>
  5. 配置SqlSessionFactory:
  6. 在之前的mybatis中提到过,使用MybatisUtils工具类来封装SqlSession相关对象的构建,而现在我们将在Spring application context中对这些对象进行配置注入。
    <!--1、SqlSessionFactoryBean:实现了接口org.springframework.beans.factory.FactoryBean-->
    <!--2、SqlSessionFactory:通过SqlSessionFactoryBean对象的getObject()方法来构建-->
    <!--3、dataSource和mapperLocations:getObject()方法中创建SqlSessionFactory对象的属性-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="mapperLocations" value="classpath*:com/zx/demo/mybatis/**/*.xml"/>
    </bean>
  7. 配置Mapper:
  8. <!--1、MapperFactoryBean:实现了接口org.springframework.beans.factory.FactoryBean-->
    <!--2、StudentMapper:通过MapperFactoryBean对象的getObject()方法来构建-->
    <!--3、mapperInterface和sqlSessionFactory:getObject()方法中创建StudentMapper接口代理实现对象的属性-->
    <bean id="exampleMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
        <property name="mapperInterface" value="com.zx.demo.mybatis.spring.mapper.StudentMapper"/>
        <property name="sqlSessionFactory" ref="sqlSessionFactory"/>
    </bean>
  9. 编写测试:
  10. public class MybatisTest {
        @Test
        public void test() throws Exception {
            ApplicationContext context = new ClassPathXmlApplicationContext("spring-context.xml");
            StudentMapper mapper = (StudentMapper) context.getBean("exampleMapper");
            List<Map<Object, Object>> maps = mapper.queryAll();
            for (Map<Object, Object> map : maps) {
                for (Object o : map.keySet()) {
                    System.out.println(o.toString() + ":" + map.get(o));
                }
                System.out.println("===");
            }
        }
    }
    工程结构如下:
    screenshot
    现在运行测试结果如下:
    screenshot

更多

更多详细进阶配置,请参考官网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值