1 簡(jiǎn)介
創(chuàng)新互聯(lián)致力于互聯(lián)網(wǎng)網(wǎng)站建設(shè)與網(wǎng)站營(yíng)銷,提供網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)站開發(fā)、seo優(yōu)化、網(wǎng)站排名、互聯(lián)網(wǎng)營(yíng)銷、小程序制作、公眾號(hào)商城、等建站開發(fā),創(chuàng)新互聯(lián)網(wǎng)站建設(shè)策劃專家,為不同類型的客戶提供良好的互聯(lián)網(wǎng)應(yīng)用定制解決方案,幫助客戶在新的全球化互聯(lián)網(wǎng)環(huán)境中保持優(yōu)勢(shì)。
1.1 單參數(shù)
在 Mybatis 中, 很多時(shí)候, 我們傳入接口的參數(shù)只有一個(gè)。 對(duì)應(yīng)接口參數(shù)的類型有兩種, 一種是基本的參數(shù)類型, 一種是 JavaBean 。
例如在根據(jù)主鍵獲取對(duì)象時(shí), 我們只需要傳入一個(gè)主鍵的參數(shù)即可。 而在插入, 更新等操作時(shí), 一般會(huì)涉及到很多參數(shù), 我們就使用 JavaBean 。
1.2 多參數(shù)
但是, 在實(shí)際的情況中, 我們遇到類似這樣的情況可能:
比如 獲取一段時(shí)間產(chǎn)生的日志信息, 日志對(duì)應(yīng)的 JavaBean 只有一個(gè)日期, 那我們使用該 JavaBean 就無(wú)法滿足我們的要求。
又比如我們進(jìn)行模糊搜索, 搜索條件只有兩個(gè), 但對(duì)應(yīng)的 JavaBean 有 50+ 個(gè)成員變量, 那創(chuàng)建對(duì)應(yīng)的 JavaBean 就過(guò)于浪費(fèi)了。
對(duì)此, 我知道的有如下幾種方法
2 多個(gè)接口參數(shù)的兩種使用方式
2.1 Map 方法(不推薦)
Map 方法的使用很簡(jiǎn)單, 就是將對(duì)應(yīng)的參數(shù)以 key-value 的方式存儲(chǔ), key 對(duì)應(yīng) SQL 中的參數(shù)名字, value 對(duì)應(yīng)需要傳入的參數(shù)值。
以獲取一段時(shí)間內(nèi)存儲(chǔ)的用戶為例
2.1.1 創(chuàng)建接口方法
/** * 獲取一段時(shí)間內(nèi)的用戶 * @param params * @return */ ListselectBetweenCreatedTime(Map params);
該方法返回的是多個(gè)記錄, 因此使用 List 作為返回值。
2.1.2 配置對(duì)應(yīng)的SQL
id 與 之前創(chuàng)建的方法名一樣。
2.1.3 調(diào)用
@Test public void testSelectBtweenCreatedTimeMap() { Mapparams = new HashMap<>(); Calendar bTime = Calendar.getInstance(); // month 是從0~11, 所以9月是8 bTime.set(2018, Calendar.AUGUST, 29); params.put("bTime", bTime.getTime()); Calendar eTime = Calendar.getInstance(); eTime.set(2018,Calendar.SEPTEMBER,2); params.put("eTime", eTime.getTime()); SqlSession sqlSession = null; try { sqlSession = sqlSessionFactory.openSession(); StudentMapper studentMapper = (StudentMapper) sqlSession.getMapper(StudentMapper.class); List students = studentMapper.selectBetweenCreatedTime(params); for (int i = 0; i < students.size(); i++) { System.out.println(students.get(i)); } } catch (Exception e) { e.printStackTrace(); } finally { if (sqlSession != null) { sqlSession.close(); } } }
調(diào)用方法很簡(jiǎn)單, 傳入相應(yīng)的 Map 參數(shù)即可。 此時(shí), Map 中的 key 對(duì)應(yīng)。 因此, 在此例子中傳入的參數(shù)
2.2 @Param 方法(推薦)
@Param方法就是使用注解的方式,
2.2.1 創(chuàng)建接口方法
/** * 獲取指定時(shí)間內(nèi)的對(duì)象 * @param pbTime 開始時(shí)間 * @param peTime 結(jié)束時(shí)間 * @return */ ListselectBetweenCreatedTimeAnno(@Param("bTime")Date pbTime, @Param("eTime")Date peTime);
@Param(“bTime”)就是告訴 mybatis , 參數(shù) pbTime 在 SQL 語(yǔ)句中用 bTime 作為 key 。
也就是說(shuō), mybatis 幫我們完成了調(diào)用時(shí), 類似 params.put(“bTime”, pbTime) 這個(gè)過(guò)程。
2.2.2 配置 SQL 語(yǔ)句
此處的 bTime 對(duì)應(yīng)** @Param(“bTime”)** 中的 bTime , 需要完全一致。
eTime也是一樣。
2.2.3 調(diào)用
在調(diào)用時(shí), 不需要?jiǎng)?chuàng)建 Map 了, 只需要按參數(shù)提示傳入對(duì)應(yīng)的實(shí)際參數(shù)即可。
@Test public void testSelectBtweenCreatedTimeAnno() { Mapparams = new HashMap<>(); Calendar bTime = Calendar.getInstance(); // month 是從0~11, 所以9月是8 bTime.set(2018, Calendar.AUGUST, 29); Calendar eTime = Calendar.getInstance(); eTime.set(2018,Calendar.SEPTEMBER,2); SqlSession sqlSession = null; try { sqlSession = sqlSessionFactory.openSession(); StudentMapper studentMapper = (StudentMapper) sqlSession.getMapper(StudentMapper.class); List students = studentMapper.selectBetweenCreatedTimeAnno(bTime.getTime(), eTime.getTime()); for (int i = 0; i < students.size(); i++) { System.out.println(students.get(i)); } } catch (Exception e) { e.printStackTrace(); } finally { if (sqlSession != null) { sqlSession.close(); } } }
3 @Param 的優(yōu)勢(shì)
Map 方式的缺點(diǎn)就是需要手動(dòng)創(chuàng)建 Map , 并對(duì) SQL 中的參數(shù)進(jìn)行賦值。其缺點(diǎn):
相比于 Map 方式, 使用 @Param 時(shí), 我們?cè)谑褂蒙暇拖裾{(diào)用方法一樣, 傳入對(duì)應(yīng)的實(shí)際參數(shù)即可。 調(diào)用時(shí)基本不會(huì)出錯(cuò)。
4 Github
相應(yīng)代碼, 可以訪問(wèn) 我的Github-helloMybatis
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。