mybatis接收以逗號分隔的字符串批量查詢方式
接收以逗號分隔的字符串批量查詢
<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>直接粘貼進去,上面部分實現(xiàn)循環(huán)查詢,下面是針對單個字符的補充(因為單個字符不存在逗號)
如何相互轉(zhuǎn)換逗號分隔的字符串和List
如果程序員想實現(xiàn)某種功能,有兩條路可以走。一條就是自己實現(xiàn),一條就是調(diào)用別人的實現(xiàn),別人的實現(xiàn)就是所謂的API。而且大多數(shù)情況下,好多“別人”都 實現(xiàn)了這個功能。程序員有不得不在這其中選擇。大部分情況下,程序員就會知道哪個用哪個,先看到哪個用哪個。到最后,在實際項目中,同樣的功能會調(diào)用五花 八門的API。我在公司的項目中就看到了這種情況。其實,也無可厚非,我相信好多項目都是這個樣子。我們不可能要求程序員都用同一種方法。程序員可能會有 不同的好惡。為了讓程序員能快樂自由地編程,就隨他去吧!因為程序員感覺自由的時候,感覺快樂的時候,正是他們生產(chǎn)力最高的時候。
不扯淡了?;貧w正題,到底這些不同的實現(xiàn)方法或者API真的就沒有高低貴賤之分?以我遇到這個逗號分隔字符串轉(zhuǎn)List為例,探討探討:
注:下面的代碼并不能保證能運行,可能需要稍微的修改。
將逗號分隔的字符串轉(zhuǎn)換為List
方法 1: 利用JDK的Arrays類
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)換為逗號分隔符
方法 1:利用JDK(好像沒有很好的方法,需要一步一步實現(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, ",");比較下來,我的觀點就是Guava庫更靈活,適用面更廣。項目中如果沒有引入Guava的話,那就加上它。
? //拼接所有字符串
? ? 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(), ",");
? ? ? ? ? ? }
? ? }以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于Spring Boot不同的環(huán)境使用不同的配置方法
下面小編就為大家分享一篇基于Spring Boot不同的環(huán)境使用不同的配置方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Spring Boot REST國際化的實現(xiàn)代碼
本文我們將討論如何在現(xiàn)有的Spring Boot項目中添加國際化。只需幾個簡單的步驟即可實現(xiàn)Spring Boot應(yīng)用的國際化,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10

