淺談Mybatis獲取參數(shù)值的方式
Mybatis獲取參數(shù)值的兩種方式:${},#{}
- ${}本質(zhì):字符串拼接,注意:單引號要加上
- #{}:本質(zhì):占位符賦值
一、 Mybatis獲取參數(shù)值的各種情況
1.mapper接口方法的參數(shù)為單個字面量的類型
/**
* 根據(jù)用戶名來查詢信息
* @return
*/
User getUsername(String username);



既然傳入的參數(shù)有多個,那么肯定也是可以傳入多個參數(shù)的,接下來我們來看一下獲取參數(shù)的第二種情況
2.mapper接口方法的參數(shù)有多個
/**
* 通過用戶名和密碼進行驗證登錄
*/
User checkLogin(String username,String password);
@Test
public void testCheckLogin() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
User user = mapper.checkLogin("李四", "123859");
System.out.println(user);
}
下面這個是報錯信息
org.apache.ibatis.exceptions.PersistenceException:
Error querying database. Cause: org.apache.ibatis.binding.BindingException: Parameter ‘username’ not found. Available parameters are [arg1, arg0, param1, param2]
Cause: org.apache.ibatis.binding.BindingException: Parameter ‘username’ not found. Available parameters are [arg1, arg0, param1, param2]
Mybatis檢測到我們的參數(shù)有多個的時候,它會自動把參數(shù)放到Map集合中
如果想要獲得數(shù)據(jù),就應(yīng)該通過下面的方法


這里有一個注意點:
剛剛的報錯信息Available parameters are [arg1, arg0, param1, param2]
這就說明了,arg1,param1它們是存儲在一起的,所以我們其實是可以混合使用者兩個的

使用${}來獲取參數(shù)值的使用方式是一樣的,這里就不演示了,大家可以自己試試,不過再次強調(diào):${}本質(zhì)是字符串拼接,我們使用的時候記得加上單引號
總結(jié):第二中方式就是通過mybatis自定義的key來訪問數(shù)據(jù),下面的第三種方式我們可以自定義key來訪問
3.手動把參數(shù)放在map集合中
如果mapper接口中的方法的參數(shù)有多個的時候,我們可以手動把參數(shù)放在map集合中存儲
mapper接口中定義的方法 User checkLoginByMap(Map<String,Object> map);
測試程序
InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
Map<String, Object> map = new HashMap<>();
map.put("username","張三");
map.put("password","123456");
User user=mapper.checkLoginByMap(map);
System.out.println(user);

總結(jié):第三種方式:我們可以自定義key來訪問,技巧:mapper接口的方法參數(shù)是map集合,我們在測試程序的時候,存儲數(shù)據(jù)的時候,可以指定存儲的key的值

還有一種獲取參數(shù)值的形式就是,前端通過表單把完整數(shù)據(jù)傳給后端,我們可以獲取數(shù)據(jù),并且把數(shù)據(jù)存到對應(yīng)的實體類中, 這個時候,當(dāng)我們調(diào)用service方法,那么傳輸過來的數(shù)據(jù)應(yīng)該就是實體類對象。實體類對象是屬性名=值這樣來存儲數(shù)據(jù),map集合是key=value的形式來存儲數(shù)據(jù),這兩種方式存儲數(shù)據(jù)其實是很像的
4.mapper接口方法的參數(shù)是實體類型的參數(shù)
/**
* 添加用戶信息
*/
int insertUser(User user);
@Test
public void testInsertUser() throws IOException {
InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
User user=new User();
user.setId(15);
user.setUsername("錢七");
user.setPassword("5613");
int i = mapper.insertUser(user);
System.out.println(i);
}


總結(jié):通過#{}或${}以屬性的方式來訪問屬性值,再次強調(diào)${}的單引號問題,需要注意。如果我們#{}括號里面的值不是屬性名那么就會報錯
5.通過@Param注解命名參數(shù)(比較常用)
使用@Param注解來命名參數(shù),此時Mybatis會把這些參數(shù)放在一個map集合中,以兩種方式來進行存儲
①@Param注解的值為鍵,參數(shù)為值
②以param1,param2…作為鍵,以參數(shù)為值
我們只需要通過#{}和${} 以鍵的形式來訪問值就可以了

測試
username,@Param("password") String password);-->
<select id="checkLoginByParam" resultType="com.atguigu.mybatis.pojo.User">
select * from t_user where username=#{param1} and password= #{password};
</select> 注意點:這個時候,存儲的key,value形式有兩種,一種形式的key是我們職工時候通過注解來命名的參數(shù)的名字,還有一種就是以param1,param2……作為key,所以這兩種形式都可以用來取數(shù)據(jù),不可以用arg0,arg1的形式來獲取數(shù)據(jù),要和情況2區(qū)分開


二、總結(jié)
上面講的五種情況,可以歸結(jié)為兩種情況,一種是參數(shù)類型為實體類型,第二種類型是通過@Param注解來命名參數(shù)
三、Param源碼分析

由于我也是剛學(xué)習(xí)Mybatis的相關(guān)內(nèi)容,所以理解可能不夠到位,這里我推薦大家可以看這篇文章MyBatis源碼解讀 - @Param注解。
以后,我還會回頭來更新Mybatis源碼相關(guān)的內(nèi)容,初學(xué)者的話,大家先以熟練使用為主,然后再慢慢的理解其中底層的原理,不要一下子就鉆進源碼中,這樣可能導(dǎo)致畏難心理,這是我的一點體會。
到此這篇關(guān)于淺談Mybatis獲取參數(shù)值的方式的文章就介紹到這了,更多相關(guān)Mybatis獲取參數(shù)值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
史上最全最強SpringMVC詳細示例實戰(zhàn)教程(圖文)
這篇文章主要介紹了史上最全最強SpringMVC詳細示例實戰(zhàn)教程(圖文),需要的朋友可以參考下2016-12-12
HTTP基本認證(Basic Authentication)的JAVA實例代碼
下面小編就為大家?guī)硪黄狧TTP基本認證(Basic Authentication)的JAVA實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
Java使用x-www-form-urlencoded發(fā)請求方式
在開發(fā)中經(jīng)常使用JSON格式,但遇到x-www-form-urlencoded格式時,可以通過重新封裝處理,POSTMan和APIpost工具中對此編碼的稱呼不同,分別是x-www-form-urlencoded和urlencoded,分享這些經(jīng)驗希望對他人有所幫助2024-09-09
SpringBoot整合阿里云OSS對象存儲服務(wù)實現(xiàn)文件上傳
這篇文章主要介紹了SpringBoot整合阿里云OSS對象存儲實現(xiàn)文件上傳,幫助大家更好的理解和學(xué)習(xí)使用SpringBoot,感興趣的朋友可以了解下2021-04-04
idea創(chuàng)建spring boot工程及配置文件(最新推薦)
本文給大家介紹idea創(chuàng)建spring boot工程及配置文件,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11

