詳細聊聊Mybatis中萬能的Map
萬能的Map
假設(shè),我們的實體類,或者數(shù)據(jù)庫中的表,字段或者參數(shù)過多,我們需要考慮使用Map
簡單來說,map你用什么參數(shù)就寫什么參數(shù),而實體類需要寫所有參數(shù)。
map不需要名稱完全對應(yīng),通過鍵的映射取值,實體類必須要求和實體類中屬性名字一樣
map傳遞參數(shù),直接在sql中取出key即可 【parameterType=“map”】
對象傳遞參數(shù),直接在sql中取對象的屬性即可 【parameterType=“Object”】
只有一個基本類型 (如int),可以直接在sql中找到
多個參數(shù)用Map或者注解
demo
map 實現(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 實現(xiàn)通過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(); }
多個參數(shù)可以使用Map進行傳參
xml文件SQL語句
<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中萬能的Map的文章就介紹到這了,更多相關(guān)Mybatis中的Map內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Cloud Alibaba Nacos Config配置中心實現(xiàn)
這篇文章主要介紹了Spring Cloud Alibaba Nacos Config配置中心實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04SpringBoot與spring security的結(jié)合的示例
這篇文章主要介紹了SpringBoot與spring security的結(jié)合的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03Java中spring boot 字符串判斷是否為空方法小結(jié)
這篇文章主要介紹了Java中spring boot字符串判斷是否為空,通過安裝依賴,結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11Java簡單實現(xiàn)調(diào)用命令行并獲取執(zhí)行結(jié)果示例
這篇文章主要介紹了Java簡單實現(xiàn)調(diào)用命令行并獲取執(zhí)行結(jié)果,結(jié)合實例形式分析了Java調(diào)用ping命令并獲取執(zhí)行結(jié)果相關(guān)操作技巧,需要的朋友可以參考下2018-08-08