欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳細聊聊Mybatis中萬能的Map

 更新時間:2021年12月12日 11:11:27   作者:冷丁_  
最近有個需求,就是使用mybatis時,向mysql中插入數(shù)據(jù),其參數(shù)為map類型,下面這篇文章主要給大家介紹了關(guān)于Mybatis中萬能的Map的相關(guān)資料,需要的朋友可以參考下

萬能的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)文章

  • Springboot AOP開發(fā)教程

    Springboot AOP開發(fā)教程

    AOP是OOP的延續(xù),是軟件開發(fā)中的一個熱點,也是Spring框架中的一個重要內(nèi)容,是函數(shù)式編程的一種衍生范型,本文給大家介紹Springboot AOP開發(fā)教程,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Spring Cloud Alibaba Nacos Config配置中心實現(xiàn)

    Spring Cloud Alibaba Nacos Config配置中心實現(xiàn)

    這篇文章主要介紹了Spring Cloud Alibaba Nacos Config配置中心實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • SpringBoot與spring security的結(jié)合的示例

    SpringBoot與spring security的結(jié)合的示例

    這篇文章主要介紹了SpringBoot與spring security的結(jié)合的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Java基于正則實現(xiàn)的日期校驗功能示例

    Java基于正則實現(xiàn)的日期校驗功能示例

    這篇文章主要介紹了Java基于正則實現(xiàn)的日期校驗功能,涉及java文件讀取、日期轉(zhuǎn)換及字符串正則匹配相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03
  • Java中spring boot 字符串判斷是否為空方法小結(jié)

    Java中spring boot 字符串判斷是否為空方法小結(jié)

    這篇文章主要介紹了Java中spring boot字符串判斷是否為空,通過安裝依賴,結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • idea 實現(xiàn)搜索jdk中的類和包操作

    idea 實現(xiàn)搜索jdk中的類和包操作

    這篇文章主要介紹了idea 實現(xiàn)搜索jdk中的類和包操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • 最好的Java 反編譯工具的使用對比分析

    最好的Java 反編譯工具的使用對比分析

    恰好最近工作中也需要用到 Java 反編譯,所以這篇文章介紹目前常見的的幾種 Java 反編譯工具的使用,在文章的最后也會通過編譯速度、語法支持以及代碼可讀性三個維度,對它們進行測試,分析幾款工具的優(yōu)缺點,感興趣的朋友一起看看吧
    2021-05-05
  • dubbo新手學(xué)習(xí)之事件通知實踐教程

    dubbo新手學(xué)習(xí)之事件通知實踐教程

    這篇文章主要給大家介紹了關(guān)于dubbo新手學(xué)習(xí)之事件通知實踐的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • Java簡單實現(xiàn)調(diào)用命令行并獲取執(zhí)行結(jié)果示例

    Java簡單實現(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
  • Java多線程 中斷機制及實例詳解

    Java多線程 中斷機制及實例詳解

    這篇文章主要介紹了Java多線程 中斷機制及實例詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09

最新評論