日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MyBatis-10MyBatis注解方式之Provider注解

發布時間:2025/3/21 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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注解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。