mybatis和spring的整合之路

来源:互联网 发布:vr软件 编辑:程序博客网 时间:2024/06/07 07:08

  mybatis是什么?

   mybatis是一个持久层的框架,是Apache下的顶级项目。

   mybatis让开发人员将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成(半自动化。大部分需要开发人员编写sql)满足需要sql语句。

   mybatis可以将向preparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象(输出映射)。

   mybatis和spring的整合

   

   我们的需求为:用mybatis和spring整合实现根据id查询用户信息,我们需要创建mybatis的全局配置文件SqlMapConfig.xml,需要创建spring的全局配置文件applicationContext.xml。

   如果持久层使用的hibernate,我们会创建一个实体类,然后创建对应的*.hbm.xml,用于建立实体和数据表的映射。如果持久层是mybatis呢,则是另一种设计理念。

   我们需要创建一个访问t_user表的UserMapper.java类,然后将访问t_user表的方法和sql语句写在UserMapper.xml配置文件中。

package com.tgb.ssm.mapper;import com.tgb.ssm.po.User;public interface UserMapper {// 根据id查询用户信息public User findUserById(int id) throws Exception;}
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- namespace命名空间,作用就是对sql进行分类化管理,理解sql隔离 注意:使用mapper代理方法开发,namespace有特殊重要的作用 --><mapper namespace="com.tgb.ssm.mapper.UserMapper"><!-- 在 映射文件中配置很多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="User">SELECT* FROM USER WHEREid=#{value}</select></mapper>
           UserMapper.java和UserMapper.xml需要遵循以下开发规范:

    1.在UserMapper.xml中的namespace等于UserMapper接口地址;

    2.UserMapper.java接口中的方法名和UserMapper.xml中statement的id一致;

    3.UserMapper.java接口中的方法输入参数类型和UserMapper.xml中的parameterType指定的类型一致;

    4.UserMapper.java接口中的方法返回值和UserMapper.xml中statement的resultType指定的类型一致;

    正因为我们遵循了mybatis的开发规范,所以我们可以在applicationContext.xml中统一配置自动创建*Mapper的代理对象。

<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd "><!-- 加载配置文件 --><context:property-placeholder location="classpath: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="mybatis/SqlMapConfig.xml"></property><!-- 数据源 --><property name="dataSource" ref="dataSource"></property></bean><!-- mapper批量扫描,从mapper包中扫描出mapper接口,自动创建代理对象并且在spring容器中注册 遵循规范:将mapper.java和mapper.xml映射文件名称保持一致,且在一个目录中。自动扫描出来的mapper的bean的id为mapper类名(首字母小写) --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 指定扫描的包名 如果扫描多个包,每个包中间使用半角逗号分隔 --><property name="basePackage" value="com.tgb.ssm.mapper" /><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" /></bean></beans>

       根据mybatis的“自动扫描出来的mapper的bean的id为mapper类名(首字母小写)”规范,我们可以方便的调用mapper类,测试方法如下:

package com.tgb.ssm.mapper;import org.junit.Before;import org.junit.Test;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import com.tgb.ssm.po.User;public class UserMapperTest {private ApplicationContext applicationContext;@Beforepublic void setUp() throws Exception {applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");}@Testpublic void testFindUserById() throws Exception {UserMapper userMapper = (UserMapper) applicationContext.getBean("userMapper");User user = userMapper.findUserById(1);System.out.println(user);}}
     通过上述讲解可以发现,如果我们使用mybatis作为持久层,我们只需创建一个访问t_user的UserMapper接口和手写sql的UserMapper.xml的配置文件,mybatis会为我们创建对应的代理类,完成对t_user的访问,大大提高了系统的灵活性。

   mybatis和hibernate本质区别:

   hibernate:一个标准的ORM框架(对象关系映射),入门门槛较高,不需要开发人员写sql,sql语句自动生成,对sql语句进行优化、修改比较困难。

   应用场景:适用于需求变化不多的中小型项目,比如:后台管理系统、erp、orm、oa。

   mybatis:专注于sql本身,需要开发人员自己编写sql语句,sql优化、修改比较方便。mybatis是一个不完全的ORM框架,虽然开发人员自己写sql,mybatis也可以实现映射(输入映射、输出映射)。

   应用场景:适用于需求变化较多的项目,比如:互联网项目。

1 0
原创粉丝点击