去掉参数中第一个“,”

       记录一下,前端传参中,传给我参数是“categoryIds: ,1731557494586241026,1731569816263311362,1731569855534579713,1731858335179223042,1731858366821052418”


      但是后端,因为我的mybati是in查询,所以因为第一个是“,”。所以会导致系统报错。
 

下面提供三个解决方法:
方法一:

找前端,让前端改!!

方法二(修改mybatis):
<if test="pd.categoryIds != null and pd.categoryIds.trim() != ''">
    <choose>
        <when test="pd.categoryIds.startsWith(',')">
            <bind name="categoryIds" value="pd.categoryIds.substring(1)" />
        </when>
        <otherwise>
            <bind name="categoryIds" value="pd.categoryIds" />
        </otherwise>
    </choose>
    AND a.category_id IN (${categoryIds})
</if>

      在这个改进后的条件语句中,我们首先使用 trim() 方法去除 categoryIds 字符串两端的空格。然后使用 startsWith(',') 方法判断是否以逗号开头,如果是则使用 substring(1) 方法去除开头的逗号。最后,我们将处理后的 categoryIds 值赋给一个新的变量 categoryIds,并在条件语句中使用它来构建查询条件。

方法三:
    if (categoryIds.startsWith(",")) {
            categoryIds = categoryIds.substring(1);
        }

        String[] categoryIdArr = categoryIds.split(",");
        List<Long> categoryIdList = new ArrayList<>();

        for (String categoryId : categoryIdArr) {
            categoryIdList.add(Long.parseLong(categoryId.trim()));
        }
  1. 如果 categoryIds 字符串以逗号开头,那么使用 substring(1) 方法去掉开头的逗号。这是因为在查询条件中,逗号前面不应该有任何字符。
  2. 使用 split(",") 方法将 categoryIds 字符串按逗号分隔成多个字符串,然后赋值给一个名为 categoryIdArr 的字符串数组。这个数组包含了多个类别 ID 字符串。
  3. 创建一个名为 categoryIdList 的空列表,用于存储将要查询的类别 ID。
  4. 遍历 categoryIdArr 数组中的每个字符串,在遍历过程中,使用 Long.parseLong() 方法将字符串解析成 Long 类型,并且使用 trim() 方法去除字符串两端的空格。然后,将解析后的 Long 类型值添加到 categoryIdList 列表中。
  5. 最后,当循环遍历完成后,categoryIdList 列表中包含了多个类别 ID 的 Long 类型值,这个列表就可以用于查询数据了。

相关推荐

  1. 如果去掉前端请求参数的前后空格?

    2023-12-06 05:22:01       66 阅读
  2. excel怎么快速去掉空行

    2023-12-06 05:22:01       36 阅读
  3. 【PHP】取出数组第一元素

    2023-12-06 05:22:01       58 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-06 05:22:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-06 05:22:01       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-06 05:22:01       82 阅读
  4. Python语言-面向对象

    2023-12-06 05:22:01       91 阅读

热门阅读

  1. 记录 | linux下互换键盘的Ctrl和CapsLock键

    2023-12-06 05:22:01       57 阅读
  2. 【MODBUS】Modbus 主从模式的部署方式

    2023-12-06 05:22:01       63 阅读
  3. rust 包模块组织结构

    2023-12-06 05:22:01       58 阅读
  4. centos 7 下运行route -n,报命令不存在

    2023-12-06 05:22:01       58 阅读
  5. postgresql_conf中常用配置项

    2023-12-06 05:22:01       44 阅读
  6. python django 新闻协同过滤算法推荐系统

    2023-12-06 05:22:01       63 阅读
  7. ajax与axios的区别

    2023-12-06 05:22:01       67 阅读
  8. WPF DataGrid 动态增加列

    2023-12-06 05:22:01       57 阅读