1、采用數據映射器(MapperFactoryBean)的方式
不用寫mybatis映射文件,采用注解方式提供相應的sql語句和輸入參數。
(1)Spring配置文件:
<!-- 引入jdbc配置文件 --> <context:property-placeholder location="jdbc.properties"/> <!--創建jdbc數據源 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="initialSize" value="${initialSize}"/> <property name="maxActive" value="${maxActive}"/> <property name="maxIdle" value="${maxIdle}"/> <property name="minIdle" value="${minIdle}"/> </bean> <!-- 創建SqlSessionFactory,同時指定數據源--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> </bean> <!--創建數據映射器,數據映射器必須為接口--> <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean"> <property name="mapperInterface" value="com.xxt.ibatis.dbcp.dao.UserMapper" /> <property name="sqlSessionFactory" ref="sqlSessionFactory" /> </bean> <bean id="userDaoImpl2" class="com.xxt.ibatis.dbcp.dao.impl.UserDaoImpl2"> <property name="userMapper" ref="userMapper"/> </bean>
(2)數據映射器UserMapper,代碼如下:
(3) dao接口類UserDao,代碼如下:
(4)dao實現類UserDaoImpl2,代碼如下:
2、采用接口org.apache.ibatis.session.SqlSession的實現類org.mybatis.spring.SqlSessionTemplate
mybatis中, sessionFactory可由SqlSessionFactoryBuilder來創建。MyBatis-Spring 中,使用了SqlSessionFactoryBean來替代。SqlSessionFactoryBean有一個必須屬性dataSource,另外其還有一個通用屬性configLocation(用來指定mybatis的xml配置文件路徑)。
(1)Spring配置文件:
<!-- 創建SqlSessionFactory,同時指定數據源--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- 指定sqlMapConfig總配置文件,訂制的environment在spring容器中不再生效--> <property name="configLocation" value="classpath:sqlMapConfig.xml"/> <!--指定實體類映射文件,可以同時指定某一包以及子包下面的所有配置文件,mapperLocations和configLocation有一個即可,當需要為實體類指定別名時,可指定configLocation屬性,再在mybatis總配置文件中采用mapper引入實體類映射文件 --> <!- - <property name="mapperLocations" value="classpath*:com/xxt/ibatis/dbcp/**/*.xml"/> --> </bean> <bean id="sqlTemplate" class="org.mybatis.spring.SqlSessionTemplate"> <constructor-arg index="0" ref="sqlSessionFactory" /> </bean>
(2)mybatis總配置文件sqlMapConfig.xml:
(3)實體類映射文件user.map.xml:
(4)dao層接口實現類UserDaoImpl:
public class UserDaoImpl implements UserDao { @Resource public SqlSessionTemplate sqlSessionTemplate; public User getUserById(User user) { return (User)sqlSessionTemplate.selectOne("com.xxt.ibatis.dbcp.domain.User.getUser", user); } }
3、采用抽象類org.mybatis.spring.support.SqlSessionDaoSupport提供SqlSession
(1)spring配置文件:
(2) dao層接口實現類UserDaoImpl3:
public class UserDaoImpl3 extends SqlSessionDaoSupport implements UserDao { public User getUserById(User user) { return (User) getSqlSession().selectOne("com.xxt.ibatis.dbcp.domain.User.getUser", user); } }
4、MapperScannerConfigurer 配置
為了代替手工使用 SqlSessionDaoSupport 或 SqlSessionTemplate 編寫數據訪問對象 (DAO)的代碼,MyBatis-Spring 提供了一個動態代理的實現:MapperFactoryBean。這個類 可以讓你直接注入數據映射器接口到你的 service 層 bean 中。當使用映射器時,你僅僅如調 用你的 DAO 一樣調用它們就可以了,但是你不需要編寫任何 DAO 實現的代碼,因為 MyBatis-Spring 將會為你創建代理。
示例
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.isea533.mybatis.mapper"/> <property name="annotationClass" value="XXX"/> <property name="sqlSessionFactoryBeanName" ref="sqlSessionFactory"/> </bean>
一般用過的最多也就是這3個屬性,實際情況下最常用的只有basePackage
。
basePackage
屬性
basePackage
可以寫多個,可以用,;\t\n
進行分割。
每一個路徑都可以用直接的包路徑,或者Ant風格的表達式。
annotationClass
屬性
該屬性實際上就是起到一個過濾的作用,如果設置了該屬性,那么MyBatis的接口只有包含該注解,才會被掃描進去。
sqlSessionFactoryBeanName
屬性
這個屬性一般都用不到,只有當你配置多數據源的時候,這是會有多個sqlSessionFactory
,你就需要通過該屬性來指定哪一個sqlSessionFactory
(值為SqlSessionFactoryBean
<bean>
配置中的id
屬性)。
5、TKmybatis
tkmybatis是在mybatis框架的基礎上提供了很多工具,讓開發更加高效,下面來看看這個框架的基本使用。
實現對員工表的增刪改查的代碼
java的dao層接口
public interface WorkerMapper extends Mapper<Worker> { }
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"> <mapper namespace="com.jjs.kaiwen.dao.WorkerMapper"> <resultMap id="BaseResultMap" type="com.jjs.kaiwen.model.Worker"> <!-- WARNING - @mbggenerated --> <id column="id" jdbcType="INTEGER" property="id" /> <result column="worker_id" jdbcType="VARCHAR" property="workerId" /> <result column="name" jdbcType="VARCHAR" property="name" /> <result column="org_id" jdbcType="INTEGER" property="orgId" /> <result column="status" jdbcType="VARCHAR" property="status" /> <result column="role_id" property="roleId" jdbcType="INTEGER" /> </resultMap> </mapper>
實體對象
@Table(name = "worker") public class Worker { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer id; @Column(name = "worker_id") private String workerId; private String name; @Column(name = "org_id") private Integer orgId; private String status; @Column(name = "role_id") private Integer roleId; // getters and setters ... }
以上就是實現對Worker進行增刪改查的所有代碼,包括選擇性更新、插入、刪除等,所有的方法列表如下
以后對表字段的添加或修改只需要更改實體對象的注解,不需要修改xml映射文件,如將worker_id改成worker_no
@Column(name = "worker_no") private String workerNo;
數據源的配置,只需要將org.mybatis.spring.mapper.MapperScannerConfigurer改成tk.mybatis.spring.mapper.MapperScannerConfigurer,然后加一個屬性
,也可不加,因為框架提供了默認實現
<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" /> <property name="basePackage" value="com.jjs.zanbi.dao" /> <property name="properties"> <value> mappers=tk.mybatis.mapper.common.Mapper </value> </property> </bean>
附錄
SqlSessionFactoryBean配置
參考官方文檔:https://mybatis.github.io/spring/zh/factorybean.html
在基本的 MyBatis 中,session 工廠可以使用 SqlSessionFactoryBuilder 來創建。而在 MyBatis-Spring 中,則使用 SqlSessionFactoryBean 來替代。
示例
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations"> <array> <value>classpath:mapper/*.xml</value> </array> </property> <property name="typeAliasesPackage" value="com.isea533.mybatis.model"/> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageHelper"> <property name="properties"> <value> dialect=hsqldb reasonable=true </value> </property> </bean> <bean class="com.github.abel533.mapperhelper.MapperInterceptor"> <property name="properties"> <value> mappers=com.github.abel533.mapper.Mapper IDENTITY=MYSQL notEmpty=true </value> </property> </bean> </array> </property> </bean>
dataSource
屬性
該屬性必須配置,多數據源時會有多個dataSource
,同時也需要配置多個sqlSessionFactory
來對應。
mapperLocations
屬性
配置該屬性后,sqlSessionFactory
會自動掃描該路徑下的所有文件並解析。
該路徑支持多個,可以用,;\t\n
進行分割。
每一個路徑都可以用直接的包路徑,或者Ant風格的表達式。
configLocation
屬性
上面例子中並沒有使用該屬性,當SqlSessionFactoryBean
提供的配置不能滿足使用時,你可以使用mybatis-config.xml
配置文件配置其他屬性,然后通過configLocation
屬性指定該配置的路徑,SqlSessionFactoryBean
會使用該配置文件創建Configuration
。
typeAliasesPackage
屬性
該屬性可以給包中的類注冊別名,注冊后可以直接使用類名,而不用使用全限定的類名(就是不用包含包名)。mybatis會自動掃描你指定包下面的javabean, 並且默認設置一個別名,默認的名字為:javabean 的首字母小寫的非限定類名來作為它的別名。
該屬性可以配置多個,可以用,;\t\n
進行分割。但是不支持Ant風格的路徑。
舉例:
<property name="typeAliasesPackage" value="cn.itcast.core.bean"/>。在Mapper文件里面就可以直接寫對應的類名 而不用寫全路徑名了 。
plugins
屬性
該屬性可以配置MyBatis的攔截器,攔截器的配置順序會影響攔截器的執行順序。
從上往下的攔截器,實際的執行順序是這樣,第一個攔截器會最后執行,最后一個會首先執行。
然后出攔截器的順序和配置的順序一致,第一個最先返回,最后一個最后返回。
就以上面的配置為例,一個簡單的執行順序圖如下:
這些攔截器執行的順序都是環繞型,不要簡單理解為簡單的順序執行。
從配置順序來看,第一個配置的在最里面,后面的依次環繞上一個攔截器。
Ant通配符
?
匹配任何單字符*
匹配0或者任意數量的字符**
匹配0或者更多的目錄
舉例
/project/*.a
匹配項目根路徑下所有在project路徑下的.a文件/project/p?ttern
匹配項目根路徑下 /project/pattern 和 /app/pXttern,但是不包括/app/pttern/**/example
匹配項目根路徑下 /project/example, /project/foow/example, 和 /example/project/**/dir/file.*
匹配項目根路徑下/project/dir/file.jsp, /project/foow/dir/file.html/**/*.jsp
匹配項目根路徑下任何的.jsp 文件
最長匹配原則(has more characters)
URL請求/project/dir/file.jsp
,現在存在兩個路徑匹配模式/**/*.jsp和/project/dir/*.jsp
,那么會根據模式/project/dir/*.jsp
來匹配。
以下為spring和mybatis整合的參考文檔:mybatis-spring-1.0.0-reference-simplified-chinese.pdf
參考資料
spring與mybatis三種整合方法:http://nirvana1988.iteye.com/blog/971246
MyBatis-Spring配置簡單了解:http://blog.csdn.net/isea533/article/details/45640319
mybatis-spring:http://www.mybatis.org/spring/zh/factorybean.html
TKmybatis的框架介紹和原理分析及Mybatis新特性演示:http://blog.csdn.net/shikaiwencn/article/details/52485883