詳細(xì)聊聊Mybatis中萬(wàn)能的Map
萬(wàn)能的Map
假設(shè),我們的實(shí)體類,或者數(shù)據(jù)庫(kù)中的表,字段或者參數(shù)過(guò)多,我們需要考慮使用Map
簡(jiǎn)單來(lái)說(shuō),map你用什么參數(shù)就寫(xiě)什么參數(shù),而實(shí)體類需要寫(xiě)所有參數(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ù)可以隨便寫(xiě)-->
<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)文章
Spring Cloud Alibaba Nacos Config配置中心實(shí)現(xiàn)
這篇文章主要介紹了Spring Cloud Alibaba Nacos Config配置中心實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
SpringBoot與spring security的結(jié)合的示例
這篇文章主要介紹了SpringBoot與spring security的結(jié)合的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
Java基于正則實(shí)現(xiàn)的日期校驗(yàn)功能示例
這篇文章主要介紹了Java基于正則實(shí)現(xiàn)的日期校驗(yàn)功能,涉及java文件讀取、日期轉(zhuǎn)換及字符串正則匹配相關(guān)操作技巧,需要的朋友可以參考下2017-03-03
Java中spring boot 字符串判斷是否為空方法小結(jié)
這篇文章主要介紹了Java中spring boot字符串判斷是否為空,通過(guò)安裝依賴,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11
idea 實(shí)現(xiàn)搜索jdk中的類和包操作
這篇文章主要介紹了idea 實(shí)現(xiàn)搜索jdk中的類和包操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02
dubbo新手學(xué)習(xí)之事件通知實(shí)踐教程
這篇文章主要給大家介紹了關(guān)于dubbo新手學(xué)習(xí)之事件通知實(shí)踐的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Java簡(jiǎn)單實(shí)現(xiàn)調(diào)用命令行并獲取執(zhí)行結(jié)果示例
這篇文章主要介紹了Java簡(jiǎn)單實(shí)現(xiàn)調(diào)用命令行并獲取執(zhí)行結(jié)果,結(jié)合實(shí)例形式分析了Java調(diào)用ping命令并獲取執(zhí)行結(jié)果相關(guān)操作技巧,需要的朋友可以參考下2018-08-08

