MyBatis-10MyBatis注解方式之Provider注解
生活随笔
收集整理的這篇文章主要介紹了
MyBatis-10MyBatis注解方式之Provider注解
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
- 概述
- @SelectProvider
- 1.開發PrivilegeProvider類
- 2.PrivilegeMapper接口增加接口方法
- 3.單元測試
- 小結
概述
除了@Select @Insert @Update @Delete四種注解可以使用簡單的SQL外,MyBatis還提供了4中Provider注解,分別是 @SelectProvider @InsertProvider @UpdateProvider @DeleteProvider .同樣可以實現CRUD操作。
下面通過@SelectProvider來了解下Provider注解方式的基本用法
@SelectProvider
1.開發PrivilegeProvider類
package com.artisan.mybatis.xml.provider;/*** * * @ClassName: PrivilegeProvider* * @Description: 權限Mapper對應的Provider實現* * @author: Mr.Yang* * @date: 2018年4月19日 上午3:30:41*/ public class PrivilegeProvider {/*** * * @Title: selectSysPrivilegeById* * @Description: 記得數據庫字段和Java實體類屬性映射,否則取出的來的是null* * @param id* @return* * @return: String*/public String selectSysPrivilegeById(Long id) {return "SELECT id, privilege_name privilegeName, privilege_url privilegeUrl FROM sys_privilege WHERE id = #{id} ";}} Provider注解中提供了兩個必填屬性 type和method.
type配置的是一個包含method屬性指定方法的類,這個類必須有空的構造函數。 這個方法的值就是要執行的SQL,并且method屬性指定的方法返回值必須是String類型。
如果SQL較長后者需要拼接,推薦使用 new SQL(){…}.toString()方法
比如
public String selectSysPrivilegeById(final Long id){return new SQL(){{SELECT("id, privilege_name privilegeName, privilege_url privilegeUrl");FROM("sys_privilege");WHERE("id = #{id}");}}.toString();}2.PrivilegeMapper接口增加接口方法
package com.artisan.mybatis.xml.mapper;import org.apache.ibatis.annotations.SelectProvider;import com.artisan.mybatis.xml.domain.SysPrivilege; import com.artisan.mybatis.xml.provider.PrivilegeProvider;/*** * * @ClassName: PrivilegeMapper* * @Description: 演示Provider方式* * @author: Mr.Yang* * @date: 2018年4月19日 上午3:26:13*/ public interface PrivilegeMapper {@SelectProvider(type = PrivilegeProvider.class, method = "selectSysPrivilegeById")SysPrivilege selectSysPrivilegeById(Long id);}3.單元測試
package com.artisan.mybatis.xml.mapper;import org.apache.ibatis.session.SqlSession; import org.apache.log4j.Logger; import org.junit.Assert; import org.junit.Test;import com.artisan.mybatis.xml.domain.SysPrivilege;public class PrivilegeMapperTest extends BaseMapperTest {private static final Logger logger = Logger.getLogger(PrivilegeMapperTest.class);SqlSession sqlSession;@Testpublic void selectSysPrivilegeByIdTest() {logger.info("selectSysPrivilegeByIdTest");try {// 獲取SqlSessionsqlSession = getSqlSession();// 獲取接口PrivilegeMapper privilegeMapper = sqlSession.getMapper(PrivilegeMapper.class);// 調用接口方法SysPrivilege sysPrivilege = privilegeMapper.selectSysPrivilegeById((long) 1);// 期待不為空Assert.assertNotNull(sysPrivilege);// 期望為PrivilegeName為"用戶管理"Assert.assertEquals("用戶管理", sysPrivilege.getPrivilegeName());logger.info("sysPrivilege Info:" + sysPrivilege);} finally {sqlSession.close();}}} 2018-04-19 03:45:47,408 INFO [main] (BaseMapperTest.java:26) - sessionFactory bulit successfully 2018-04-19 03:45:47,412 INFO [main] (BaseMapperTest.java:29) - reader close successfully 2018-04-19 03:45:47,415 INFO [main] (PrivilegeMapperTest.java:19) - selectSysPrivilegeByIdTest 2018-04-19 03:45:47,904 DEBUG [main] (BaseJdbcLogger.java:145) - ==> Preparing: SELECT id, privilege_name privilegeName, privilege_url privilegeUrl FROM sys_privilege WHERE id = ? 2018-04-19 03:45:47,979 DEBUG [main] (BaseJdbcLogger.java:145) - ==> Parameters: 1(Long) 2018-04-19 03:45:48,011 TRACE [main] (BaseJdbcLogger.java:151) - <== Columns: id, privilegeName, privilegeUrl 2018-04-19 03:45:48,011 TRACE [main] (BaseJdbcLogger.java:151) - <== Row: 1, 用戶管理, /users 2018-04-19 03:45:48,015 DEBUG [main] (BaseJdbcLogger.java:145) - <== Total: 1 2018-04-19 03:45:48,016 INFO [main] (PrivilegeMapperTest.java:32) - sysPrivilege Info:SysPrivilege [id=1, privilegeName=用戶管理, privilegeUrl=/users]小結
最常用的注解我們簡單的介紹了下使用方式,但是注解方式并不是主流,因此不深究,更多用法請參考MyBatis官方項目的測試用例 11.4章節。
總結
以上是生活随笔為你收集整理的MyBatis-10MyBatis注解方式之Provider注解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MyBatis-09MyBatis注解方
- 下一篇: MyBatis-17MyBatis代码生