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

Java中MyBatis傳入?yún)?shù)parameterType問題

 更新時間:2022年12月21日 10:35:05   作者:MinggeQingchun  
這篇文章主要介紹了Java中MyBatis傳入?yún)?shù)parameterType問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

parameterType:MyBatis的傳入?yún)?shù)

參數(shù)類型主要分為兩種

(1)基本數(shù)據(jù)類型:int,string,long,Date

(2)復(fù)雜數(shù)據(jù)類型:類和Map

獲取參數(shù)中的值

(1)基本數(shù)據(jù)類型:#{參數(shù)} 獲取參數(shù)中的值

(2)復(fù)雜數(shù)據(jù)類型:#{屬性名}  ,map中則是#{key}

首先說說單參數(shù)基本數(shù)據(jù)類型,如:String,Long

一、單參數(shù)

//根據(jù)name查詢
public List<XXBean> getXXBeanList(String name); ?
?
<select id="getXXBeanList" parameterType="java.lang.String" resultType="XXBean">
  select * from User u where u.name = #{name} ?
</select> ?
?
?
//根據(jù)主鍵id查詢
public List<XXBean> getXXBeanList(Long beanId);
?
<select id="getXXBeanList" parameterType="java.lang.String" resultType="XXBean">
  select * from User u where u.userId = #{beanId} ?
</select>

其中方法名和ID一致,#{}中的參數(shù)名與方法中的參數(shù)名一致, 上面采用的是XXXBean,是采用的短名字,

select 后的字段列表要和bean中的屬性名一致, 如果不一致的可以用 as 別名 來補(bǔ)充

二、多參數(shù)

1、索引 #{index}

public List<XXBean> getXXBeanList(String beanId, String name); ?
?
<select id="getXXBeanList" resultType="XXBean">
  select * from user u where u.userId = #{0} and name = #{1} ?
</select> ?

由于是多參數(shù),不能使用parameterType, 改用#{index}是第幾個就用第幾個的索引,索引從0開始

#{0}代表接收的是dao層中的第一個參數(shù),#{1}代表dao層中第二參數(shù),更多參數(shù)一致往后加即可

2、Map封裝多參數(shù)

? ? ? ? Map<String, Object> hashmap = new HashMap<String, Object>();
? ? ? ? params.put("userId", userId);
? ? ? ? params.put("userName", userName);
?
public List<XXBean> getXXBeanList(HashMap <String, Object> hashmap); ?
?
<select id="getXXBeanList" parameterType="hashmap" resultType="XXBean">
  select * from user u where u.userId=#{userId} name = #{userName} ?
</select> ?

其中hashmap是mybatis自己配置好的直接使用就行。map中key的名字是那個就在#{}使用那個

3、List封裝in

public List<XXBean> getXXBeanList(List<String> list); ?
?
<select id="getXXBeanList" resultType="XXBean">
  select * from user where userId in
  <foreach item="userId" collection="array" open="(" separator="," close=")">
? ? ? ? ?#{userId}
? ?</foreach>
</select> ??

foreach 最后的效果是select 字段... from XX where id in ('1','2','3','4')

4、注解方式

public User getUser(@Param("userId")Long userId, @Param("name")String name);

Mapper.xml配置:

<select id="getUser" resultMap="com.xxx.xxx.User">
? ? ? ?SELECT * FROM user u?
    where u.userId=#{userId} and u.name=#{name}
</select>

5、多類型參數(shù)

selectList()只能傳遞一個參數(shù),但實(shí)際所需參數(shù)既要包含String類型,又要包含List類型時的處理方法;將參數(shù)放入Map,再取出Map中的List遍歷

List<String> list = new ArrayList<String>();
Map<String, Object> map2 = new HashMap<String, Object>();
?
list.add("1");
list.add("2");
map2.put("list", list);?
?
map2.put("roleCode", "0101");

mapper.xml

<select id="getUser" parameterType="java.util.Map" resultMap="User">
  select u,userId, u.name, u.code?
? ?from user u
? ?left join role r on r.role_userId = u.userId
? ?WHERE r.code = #{roleCode}?
? ?and r.roleId not in?
? ?<foreach item="roleId" collection="array" open="(" separator="," close=")">
? ? ? ? ?#{roleId}
? ?</foreach>
?</select>

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 代碼詳解Java猴子選王問題(約瑟夫環(huán))

    代碼詳解Java猴子選王問題(約瑟夫環(huán))

    本篇文章通過實(shí)例給大家分析了java約瑟夫環(huán)這個經(jīng)典內(nèi)容,有興趣的跟著小編一起學(xué)習(xí)下吧。
    2018-02-02
  • Java兩大工具庫Commons和Guava使用示例詳解

    Java兩大工具庫Commons和Guava使用示例詳解

    這篇文章主要為大家介紹了Java兩大工具庫Commons和Guava使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Java圖像處理教程之正片疊底效果的實(shí)現(xiàn)

    Java圖像處理教程之正片疊底效果的實(shí)現(xiàn)

    正片疊底效果是我們平時在Photoshop中會見到的一種效果,下面這篇文章主要給大家介紹了關(guān)于利用Java如何實(shí)現(xiàn)正片疊底的效果,分享出來供大家參考學(xué)習(xí),文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),需要的朋友可以參考借鑒,下面來一起看看詳細(xì)的介紹吧。
    2017-09-09
  • Netty分布式從recycler對象回收站獲取對象過程剖析

    Netty分布式從recycler對象回收站獲取對象過程剖析

    這篇文章主要為大家介紹了Netty分布式從recycler獲取對象的過程源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • Java微服務(wù)Filter過濾器集成Sentinel實(shí)現(xiàn)網(wǎng)關(guān)限流過程詳解

    Java微服務(wù)Filter過濾器集成Sentinel實(shí)現(xiàn)網(wǎng)關(guān)限流過程詳解

    這篇文章主要介紹了Java微服務(wù)Filter過濾器集成Sentinel實(shí)現(xiàn)網(wǎng)關(guān)限流過程,首先Sentinel規(guī)則的存儲默認(rèn)是存儲在內(nèi)存的,應(yīng)用重啟之后規(guī)則會丟失。因此我們通過配置中心Nacos保存規(guī)則,然后通過定時拉取Nacos數(shù)據(jù)來獲取規(guī)則配置,可以做到動態(tài)實(shí)時的刷新規(guī)則
    2023-02-02
  • Spring Boot使用profile如何配置不同環(huán)境的配置文件

    Spring Boot使用profile如何配置不同環(huán)境的配置文件

    ,springboot支持通過不同的profile來配置不同環(huán)境的配置,下面就大致介紹一下yml配置文件跟properties配置文件怎么使用profile配置不同環(huán)境的配置文件
    2018-01-01
  • springboot下ueditor上傳功能的實(shí)現(xiàn)及遇到的問題

    springboot下ueditor上傳功能的實(shí)現(xiàn)及遇到的問題

    這篇文章主要介紹了springboot下ueditor上傳功能的實(shí)現(xiàn)及遇到的問題,本文分步驟通過實(shí)例截圖給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • SpringBoot全局異常與數(shù)據(jù)校驗(yàn)的方法

    SpringBoot全局異常與數(shù)據(jù)校驗(yàn)的方法

    這篇文章主要介紹了SpringBoot全局異常與數(shù)據(jù)校驗(yàn)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • Java的RocketMq水平擴(kuò)展及負(fù)載均衡詳解

    Java的RocketMq水平擴(kuò)展及負(fù)載均衡詳解

    這篇文章主要介紹了Java的RocketMq水平擴(kuò)展及負(fù)載均衡詳解,RocketMQ是一個分布式具有高度可擴(kuò)展性的消息中間件,本文旨在探索在broker端,生產(chǎn)端,以及消費(fèi)端是如何做到橫向擴(kuò)展以及負(fù)載均衡的,需要的朋友可以參考下
    2024-01-01
  • Java  Object類中的常用API介紹

    Java  Object類中的常用API介紹

    這篇文章主要介紹了Java  Object類中的常用API介紹,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-11-11

最新評論