您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)mybatis3中@SelectProvider的使用問題怎么解決,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
mybatis3中增加了使用注解來配置Mapper的新特性,下面主要介紹其中幾個(gè)@Provider的使用方式,他們是:@SelectProvider、@UpdateProvider、@InsertProvider和@DeleteProvider。
@SelectProvider是聲明在方法基本上的,這個(gè)方法定義在Mapper對應(yīng)的的interface上。
public interface UserMapper { @SelectProvider(type = SqlProvider.class, method = "selectUser") @ResultMap("userMap") public User getUser(long userId); }
上例中是個(gè)很簡單的Mapper接口,其中定義了一個(gè)方法:getUser,這個(gè)方法根據(jù)提供的用戶id來查詢用戶信息,并返回一個(gè)User實(shí)體bean。
這是一個(gè)很簡單很常用的查詢場景:根據(jù)key來查詢記錄并將結(jié)果封裝成實(shí)體bean。其中:
@SelectProvider注解用于生成查詢用的sql語句,有別于@Select注解,@SelectProvide指定一個(gè)Class及其方法,并且通過調(diào)用Class上的這個(gè)方法來獲得sql語句。在我們這個(gè)例子中,獲取查詢sql的方法是SqlProvider.selectUser。
@ResultMap注解用于從查詢結(jié)果集RecordSet中取數(shù)據(jù)然后拼裝實(shí)體bean。
@SelectProvide中type參數(shù)指定的Class類,必須要能夠通過無參的構(gòu)造函數(shù)來初始化。
@SelectProvide中method參數(shù)指定的方法,必須是public的,返回值必須為String,可以為static。
public class SqlProvider { public String selectUser(long userId) { return "select * from user where userId=" + userId; } }
在Mapper接口方法上和@SelectProvide指定類方法上,均無參數(shù):
UserMapper.java: @SelectProvider(type = SqlProvider.class, method = "selectAllUser") @ResultMap("userMap") public List<User> getAllUser();
SqlProvider.java: public String selectAllUser() { return "select * from user"; }
對于只有一個(gè)參數(shù)的情況,可以直接使用,參見前面的getUser和selectUser。
但是,如果在getUser方法中,對userId方法使用了@Param注解的話,那么相應(yīng)selectUser方法必須接受Map<String, Object>做為參數(shù):
UserMapper.java: @SelectProvider(type = SqlProvider.class, method = "selectUser2") @ResultMap("userMap") public User getUser2(@Param("userId") long userId);
SqlProvider.java: public String selectUser2(Map<String, Object> para) { return "select * from user where userId=" + para.get("userId"); }
在超過一個(gè)參數(shù)的情況下,@SelectProvide方法必須接受Map<String, Object>做為參數(shù),
如果參數(shù)使用了@Param注解,那么參數(shù)在Map中以@Param的值為key,如下例中的userId;
如果參數(shù)沒有使用@Param注解,那么參數(shù)在Map中以參數(shù)的順序?yàn)閗ey,如下例中的password:
UserMapper.java: @SelectProvider(type = SqlProvider.class, method = "selectUserCheck") @ResultMap("userMap") public User getUserCheck(@Param("userId") long userId, String password);
SqlProvider.java: public String selectUserCheck(Map<String, Object> para) { return "select * from user where userId=" + para.get("userId") + " and password='" + para.get("1") + "'"; }
在Mapper接口和@SelectProvide方法類中,不要使用重載,也就是說,不要使用方法名相同參數(shù)不同的方法,以避免發(fā)生詭異問題。
@Repository public interface FqzRlMapInfoMapper { @SelectProvider(type = FqzRlMapInfoProvider.class, method = "findRelationInfos") List<RelationInfo> findRelationInfos(Collection<String> flags); class FqzRlMapInfoProvider { public String findRelationInfos(Collection<String> flags) { String inStr = String.join("','", flags); StringBuilder sb = new StringBuilder(); sb.append("select * from dm_screen_fqz_mapdata_2_b where 1=1 "); if (null == flags || flags.size() == 0) { sb.append(" and 1<>1 "); } else { sb.append(" and relate_flag in ('").append(inStr).append("')"); } return sb.toString(); } } }
看完上述內(nèi)容,你們對mybatis3中@SelectProvider的使用問題怎么解決有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。