滴滴撕滴颩 2022-12-19 11:38 采纳率: 57.1%
浏览 46
已结题

Java格式化mysql语句问题

问题遇到的现象和发生背景

想利用jexlEngine将sql当成代码执行,遇到格式化转换问题;

jexlEngine的等号(=)要两个等号(==)才能正常转换,当where条件是(==)则正常,如果是一个(=)或者(= =)中间有空格,我怎么判断将=好转两个==

遇到的现象和发生背景

代码如下:怎么修改才能判断到是一个=还是两个=,怎么去 = = 中间的空格?



String where = "pay_time >= '2019/10/21' and pay_time <= '2019/10/22' and pay_time = = '2019/10/22'";


public static String formatWhere(String where){

   if (where.contains("=")) {
//            where = where.replace(" ", "");
            List<Integer> strAllIndex = getStrAllIndex(where, "=");
            for (int i = 0; i < strAllIndex.size(); i++) {
                Integer index = strAllIndex.get(i);
                String targetBefore = Character.toString(where.charAt(index - 1));
                String targetEnd = Character.toString(where.charAt(index + 1));
                if (!">".equals(targetBefore) && !"<".equals(targetBefore) && !"=".equals(targetBefore) && !"!".equals(targetBefore)) {
                    if (!"=".equals(targetEnd)) {
                        where = where.substring(0, index) + "==" + where.substring(index + 1);
                    }
                }
            }
        }

        if (where.contains(" and ")) {
            where = where.replace(" and ", " && ");
        }

        if (where.contains(" AND ")) {
            where = where.replace(" AND ", " && ");
        }

        if (where.contains(" or ")) {
            where = where.replace(" or ", " || ");
        }

        if (where.contains(" OR ")) {
            where = where.replace(" OR ", " || ");
        }

//        System.out.println("where:" + where);
//        return where;

}
  • 写回答

2条回答 默认 最新

  • bingbingyihao 2022-12-19 11:48
    关注

    回答:实际判断 "= =",非常简单,且转换起来也很容易,只需要得到“=”的下标,并判断在"="后面接着出现的是否是" ="即可,如果是的话,就将这三个下标改为"=="即可,这里的话需要用到字符串拼接了,拼接出新的字符串,采用StringBuffer即可

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月28日
  • 已采纳回答 12月20日
  • 创建了问题 12月19日

悬赏问题

  • ¥15 准备学习小程序搭建,谁能手把手的教我啊?
  • ¥15 关于#嵌入式硬件#的问题:树莓派第一天重装配置python和opencv后第二天打开就成这样,瞎捣鼓搞出来文件夹还是没把原来的界面调回来
  • ¥20 Arduino 循迹小车程序电路出错故障求解
  • ¥20 Arduino 循迹小车程序电路出错故障求解
  • ¥100 AT89C52单片机C语言调试之后再回答
  • ¥15 AT89C52单片机C语言串口助手发送数据包返回值
  • ¥15 C++数组中找第二小的数字程序纠错
  • ¥50 MATLAB APP 制作出现问题
  • ¥15 wannier复现图像时berry曲率极值点与高对称点严重偏移
  • ¥15 利用决策森林为什么会出现这样·的问题(关键词-情感分析)