詳細(xì)聊聊Mybatis中萬(wàn)能的Map
萬(wàn)能的Map
假設(shè),我們的實(shí)體類,或者數(shù)據(jù)庫(kù)中的表,字段或者參數(shù)過(guò)多,我們需要考慮使用Map
簡(jiǎn)單來(lái)說(shuō),map你用什么參數(shù)就寫什么參數(shù),而實(shí)體類需要寫所有參數(shù)。
map不需要名稱完全對(duì)應(yīng),通過(guò)鍵的映射取值,實(shí)體類必須要求和實(shí)體類中屬性名字一樣
map傳遞參數(shù),直接在sql中取出key即可 【parameterType=“map”】
對(duì)象傳遞參數(shù),直接在sql中取對(duì)象的屬性即可 【parameterType=“Object”】
只有一個(gè)基本類型 (如int),可以直接在sql中找到
多個(gè)參數(shù)用Map或者注解
demo
map 實(shí)現(xiàn)add user
UserMapper接口
public interface UserMapper {
User getUserById2(Map<String,Object> map);
}
UserMaper.xml
<!-- 用map后這邊參數(shù)可以隨便寫-->
<insert id="addUser2" parameterType="map" >
insert into mybatis.user(id, name, pwd) VALUES (#{userid},#{username},#{password});
</insert>
test
@Test
public void addUser2(){
SqlSession sqlSession=MybatisUtils.getSqlSession();
UserMapper mapper=sqlSession.getMapper(UserMapper.class);
Map<String,Object> map=new HashMap<String,Object>();
map.put("userid",5);
map.put("username","王五");
map.put("password","23333");
mapper.addUser2(map);
sqlSession.commit();
sqlSession.close();
}
map 實(shí)現(xiàn)通過(guò)id查詢
UserMapper接口
public interface UserMapper {
User getUserById2(Map<String,Object> map);
}
UserMaper.xml
<select id="getUserById2" parameterType="map" resultType="com.lding.pojo.User">
select * from mybatis.user where id=#{id} and name=#{name}
</select>
test
@Test
public void getUserById2() {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map<String,Object> map=new HashMap<String,Object>();
map.put("id",1);
map.put("name","冷丁");
User userById = mapper.getUserById2(map);
System.out.println(userById);
sqlSession.close();
}
多個(gè)參數(shù)可以使用Map進(jìn)行傳參
xml文件SQL語(yǔ)句
<select id="findByPriceRange" parameterType="java.util.Map" resultType="com.itlaoqi.mybatis.entity.Goods">
select * from t_goods
where
current_price between #{min} and #{max}
order by current_price
limit 0,#{limt}
</select>
總結(jié)
到此這篇關(guān)于Mybatis中萬(wàn)能的Map的文章就介紹到這了,更多相關(guān)Mybatis中的Map內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot Maven打包插件spring-boot-maven-plugin無(wú)法解析原因
spring-boot-maven-plugin是spring boot提供的maven打包插件,本文主要介紹了SpringBoot Maven打包插件spring-boot-maven-plugin無(wú)法解析原因,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
Java Calendar類使用總結(jié)及使用實(shí)例
這篇文章主要介紹了Java Calendar類使用總結(jié)及使用實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
Java虛擬機(jī)之對(duì)象創(chuàng)建過(guò)程與類加載機(jī)制及雙親委派模型
這篇文章主要給大家介紹了關(guān)于Java虛擬機(jī)之對(duì)象創(chuàng)建過(guò)程與類加載機(jī)制及雙親委派模型的相關(guān)資料,本文通過(guò)示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-11-11
基于springboot+jwt實(shí)現(xiàn)刷新token過(guò)程解析
這篇文章主要介紹了基于springboot+jwt實(shí)現(xiàn)刷新token過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
RabbitMQ 在 Spring Boot 項(xiàng)目中的深度應(yīng)用與實(shí)戰(zhàn)解析
RabbitMQ 作為一款廣受歡迎的開源消息隊(duì)列系統(tǒng),遵循 AMQP 協(xié)議,能夠在分布式系統(tǒng)里實(shí)現(xiàn)應(yīng)用程序之間的異步通信、解耦以及流量削峰等關(guān)鍵功能,這篇文章主要介紹了RabbitMQ 在 Spring Boot 項(xiàng)目中的深度應(yīng)用與實(shí)戰(zhàn)解析,需要的朋友可以參考下2025-01-01
sqlserver和java將resultSet中的記錄轉(zhuǎn)換為學(xué)生對(duì)象
這篇文章主要介紹了如何利用sqlserver和java將resultSet中的記錄轉(zhuǎn)換為學(xué)生對(duì)象,附有超詳細(xì)的代碼,需要的朋友可以參考一下,希望對(duì)你有所幫助2021-12-12
JavaSE static final及abstract修飾符實(shí)例解析
這篇文章主要介紹了JavaSE static final及abstract修飾符實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
SpringCloud服務(wù)之間Feign調(diào)用不會(huì)帶上請(qǐng)求頭header的解決方法
在Spring?Cloud中,使用Feign進(jìn)行服務(wù)之間的調(diào)用時(shí),默認(rèn)情況下是不會(huì)傳遞header的,這篇文章給大家介紹SpringCloud服務(wù)之間Feign調(diào)用不會(huì)帶上請(qǐng)求頭header的解決方法,感興趣的朋友一起看看吧2024-01-01
Mybatis傳入List實(shí)現(xiàn)批量更新的示例代碼
這篇文章主要介紹了Mybatis傳入List實(shí)現(xiàn)批量更新的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10

