亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis接收以逗號(hào)分隔的字符串批量查詢(xún)方式

 更新時(shí)間:2022年01月21日 11:30:48   作者:RT_0114  
這篇文章主要介紹了mybatis接收以逗號(hào)分隔的字符串批量查詢(xún)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

接收以逗號(hào)分隔的字符串批量查詢(xún)

<IF test = " supplierIds !=null and supplierIds.indexOf(',') != -1 ?">?
? ? AND msd.supplier_id NOT IN?
? ? <foreach collection = "supplierIds.split(',')" item = "item"?
? ? ? ? OPEN = "(" SEPARATOR = "," CLOSE = ")"> ?
? ? ? ? ? ? #{item}
? ? </foreach>
</IF>
<IF test = "supplierIds !=null and supplierIds.indexOf(',') == -1">?
? ? AND msd.supplier_id != #{supplierIds}
</IF>

直接粘貼進(jìn)去,上面部分實(shí)現(xiàn)循環(huán)查詢(xún),下面是針對(duì)單個(gè)字符的補(bǔ)充(因?yàn)閱蝹€(gè)字符不存在逗號(hào))

如何相互轉(zhuǎn)換逗號(hào)分隔的字符串和List

如果程序員想實(shí)現(xiàn)某種功能,有兩條路可以走。一條就是自己實(shí)現(xiàn),一條就是調(diào)用別人的實(shí)現(xiàn),別人的實(shí)現(xiàn)就是所謂的API。而且大多數(shù)情況下,好多“別人”都 實(shí)現(xiàn)了這個(gè)功能。程序員有不得不在這其中選擇。大部分情況下,程序員就會(huì)知道哪個(gè)用哪個(gè),先看到哪個(gè)用哪個(gè)。到最后,在實(shí)際項(xiàng)目中,同樣的功能會(huì)調(diào)用五花 八門(mén)的API。我在公司的項(xiàng)目中就看到了這種情況。其實(shí),也無(wú)可厚非,我相信好多項(xiàng)目都是這個(gè)樣子。我們不可能要求程序員都用同一種方法。程序員可能會(huì)有 不同的好惡。為了讓程序員能快樂(lè)自由地編程,就隨他去吧!因?yàn)槌绦騿T感覺(jué)自由的時(shí)候,感覺(jué)快樂(lè)的時(shí)候,正是他們生產(chǎn)力最高的時(shí)候。

不扯淡了?;貧w正題,到底這些不同的實(shí)現(xiàn)方法或者API真的就沒(méi)有高低貴賤之分?以我遇到這個(gè)逗號(hào)分隔字符串轉(zhuǎn)List為例,探討探討:

注:下面的代碼并不能保證能運(yùn)行,可能需要稍微的修改。

將逗號(hào)分隔的字符串轉(zhuǎn)換為L(zhǎng)ist

方法 1: 利用JDK的Arrays類(lèi)

String str = "a,b,c";
List<String> result = Arrays.asList(str.split(","));

方法2:利用Guava的Splitter

? ? String str = "a, b, c";
? ? List<String> result = Splitter.on(",").trimResults().splitToList(str);

方法3:利用Apache Commons的StringUtils (只是用了split)

? String str = "a,b,c";
? ? List<String> result = Arrays.asList(StringUtils.split(str,","));

方法4:利用Spring Framework的StringUtils

? ? String str = "a,b,c";
? ? List<String> str = Arrays.asList(StringUtils.commaDelimitedListToStringArray(str));

將List轉(zhuǎn)換為逗號(hào)分隔符

方法 1:利用JDK(好像沒(méi)有很好的方法,需要一步一步實(shí)現(xiàn))

NA

方法2:利用Guava的Joiner

? ? List<String> list = new ArrayList<String>();
? ? list.add("a");
? ? list.add("b");
? ? list.add("c");
? ? String str = Joiner.on(",").join(list);

方法3:利用Apache Commons的StringUtils

? ? List<String> list = new ArrayList<String>();
? ? list.add("a");
? ? list.add("b");
? ? list.add("c");
? ? String str = StringUtils.join(list.toArray(), ",");

方法4:利用Spring Framework的StringUtils

List<String> list = new ArrayList<String>();
list.add("a");
list.add("b");
list.add("c");
String str = StringUtils.collectionToDelimitedString(list, ",");

比較下來(lái),我的觀(guān)點(diǎn)就是Guava庫(kù)更靈活,適用面更廣。項(xiàng)目中如果沒(méi)有引入Guava的話(huà),那就加上它。

? //拼接所有字符串
? ? public String getAllIdByUserMobile( List<String> userMobile) throws Exception {
? ? ? ? ? ?StringBuilder userMobileIdString = new StringBuilder();
? ? ? ? ? ?//拼接字符串 userMobile productId
? ? ? ? ? ? if( userMobile.size() <= 0){
? ? ? ? ? ? ? ? return "";
? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? for(String item:userMobile){
? ? ? ? ? ? ? ? ? ? userMobileIdString.append(item + ",");
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? return org.apache.commons.lang.StringUtils.removeEnd(userMobileIdString.toString(), ",");
? ? ? ? ? ? }
? ? }

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

相關(guān)文章

  • SSM 整合的配合文件(分享)

    SSM 整合的配合文件(分享)

    下面小編就為大家分享一篇SSM 整合的配合文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Java詳細(xì)介紹單例模式的應(yīng)用

    Java詳細(xì)介紹單例模式的應(yīng)用

    單例模式(Singleton Pattern)是 Java 中最簡(jiǎn)單的設(shè)計(jì)模式之一。這種類(lèi)型的設(shè)計(jì)模式屬于創(chuàng)建型模式,它提供了一種創(chuàng)建對(duì)象的最佳方式
    2022-09-09
  • Maven實(shí)現(xiàn)項(xiàng)目構(gòu)建工具

    Maven實(shí)現(xiàn)項(xiàng)目構(gòu)建工具

    本文主要介紹了Maven實(shí)現(xiàn)項(xiàng)目構(gòu)建工具,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • OpenJDK源碼調(diào)試圖文教程

    OpenJDK源碼調(diào)試圖文教程

    這篇文章主要介紹了OpenJDK源碼調(diào)試,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • Java文件操作類(lèi) File實(shí)現(xiàn)代碼

    Java文件操作類(lèi) File實(shí)現(xiàn)代碼

    這篇文章主要介紹了Java文件操作類(lèi) File實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2017-08-08
  • 基于Spring Boot不同的環(huán)境使用不同的配置方法

    基于Spring Boot不同的環(huán)境使用不同的配置方法

    下面小編就為大家分享一篇基于Spring Boot不同的環(huán)境使用不同的配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • Spring Boot REST國(guó)際化的實(shí)現(xiàn)代碼

    Spring Boot REST國(guó)際化的實(shí)現(xiàn)代碼

    本文我們將討論如何在現(xiàn)有的Spring Boot項(xiàng)目中添加國(guó)際化。只需幾個(gè)簡(jiǎn)單的步驟即可實(shí)現(xiàn)Spring Boot應(yīng)用的國(guó)際化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • java解析XML詳解

    java解析XML詳解

    這篇文章主要介紹了XML解析四種方式代碼示例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-07-07
  • java原生動(dòng)態(tài)生成驗(yàn)證碼

    java原生動(dòng)態(tài)生成驗(yàn)證碼

    這篇文章主要為大家詳細(xì)介紹了java原生動(dòng)態(tài)生成驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Java中TypeReference用法詳情說(shuō)明

    Java中TypeReference用法詳情說(shuō)明

    這篇文章主要介紹了Java中TypeReference用法詳情說(shuō)明,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07

最新評(píng)論