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 mapper
PUBLIC "-//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 WHERE
id=#{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;
@Before
public void setUp() throws Exception {
applicationContext = new ClassPathXmlApplicationContext(
"classpath:spring/applicationContext.xml");
}
@Test
public 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也可以实现映射(输入映射、输出映射)。
应用场景:适用于需求变化较多的项目,比如:互联网项目。