字符串逗号分割返回一个集合

下面方法你传入一个value并且带逗号的值,你将得到一个逗号分割的List列表,如果是字符串只需要把Integer类型改为string就好了。strs 传入的值将不在List列表里面返回

示例: 

value = 23,45,67,89,32,23,50
strs = 50     不在下面List列表里面返回

返回:一个List列表
23
45
67
89
32
23

  /**
     * @param value  需要截取的字符串
     * @param strs    不需要截取的字符串
     * @return
     */
    public static List<Integer> findStrings(String value, String... strs) {
        //以逗号分割,得出的数据存到 result 里面
        String[] result = value.split(",");
        List<Integer> list = new ArrayList<>();
        for (String r : result) {
            if (strs != null) {
                if (!isBlank(r)) {
                    if (!r.equals(strs[0]) && !r.equals(strs[1])) {
                        list.add(Integer.parseInt(r));
                    }
                }
            }
            if (!isBlank(r)) {
                if (isEmpty(strs)) {
                    list.add(Integer.parseInt(r));
                }
            }
        }
        return list;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你需要将一个逗号隔开的字符串分割成多个值并返回一个结果集,可以使用 MySQL 中的内置函数 `SUBSTRING_INDEX()` 和 `UNION ALL` 运算符。下面是一个示例查询: ``` SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit FROM (SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n WHERE n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1 ``` 这将返回一个包含拆分后每个值的行集合。在这个示例中,我们将字符串 'apple,banana,orange' 分割成三个部分:'apple'、'banana' 和 'orange'。你可以将这个查询作为一个子查询,将其结果与其他表进行联接,或者按照需要进行进一步处理。 如果你想将分割后的值以多行的形式返回,可以使用 `UNION ALL` 运算符连接多个 `SELECT` 语句,每个 `SELECT` 语句返回一个值。下面是一个示例查询: ``` SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('apple,banana,orange', ',', n.digit+1), ',', -1) AS fruit FROM (SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n WHERE n.digit < LENGTH('apple,banana,orange') - LENGTH(REPLACE('apple,banana,orange', ',', '')) + 1 UNION ALL SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('grape,pear,melon', ',', n.digit+1), ',', -1) AS fruit FROM (SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n WHERE n.digit < LENGTH('grape,pear,melon') - LENGTH(REPLACE('grape,pear,melon', ',', '')) + 1 ``` 在这个示例中,我们使用两个 `SELECT` 语句分别处理两个逗号隔开的字符串,然后使用 `UNION ALL` 运算符将它们的结果集合并成一个结果集。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值