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>

直接粘貼進去,上面部分實現循環查詢,下面是針對單個字符的補充(因為單個字符不存在逗號)

如何相互轉換逗號分隔的字符串和List

如果程序員想實現某種功能,有兩條路可以走。一條就是自己實現,一條就是調用別人的實現,別人的實現就是所謂的API。而且大多數情況下,好多“別人”都 實現瞭這個功能。程序員有不得不在這其中選擇。大部分情況下,程序員就會知道哪個用哪個,先看到哪個用哪個。到最後,在實際項目中,同樣的功能會調用五花 八門的API。我在公司的項目中就看到瞭這種情況。其實,也無可厚非,我相信好多項目都是這個樣子。我們不可能要求程序員都用同一種方法。程序員可能會有 不同的好惡。為瞭讓程序員能快樂自由地編程,就隨他去吧!因為程序員感覺自由的時候,感覺快樂的時候,正是他們生產力最高的時候。

不扯淡瞭。回歸正題,到底這些不同的實現方法或者API真的就沒有高低貴賤之分?以我遇到這個逗號分隔字符串轉List為例,探討探討:

註:下面的代碼並不能保證能運行,可能需要稍微的修改。

將逗號分隔的字符串轉換為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轉換為逗號分隔符

方法 1:利用JDK(好像沒有很好的方法,需要一步一步實現)

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(), ",");
            }
    }

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: