【java/正则表达式】用正则表达式解决查询语句条件输入不完全而整句SQL无需修改的问题

需求:

界面上有四个输入框,分别对应查询语句的四个参数,查询语句是:

select * from a=:av and b=:bv and c=:cv and d = : dv

当输入框没有用户输入时,该项条件即不存在,比如bv没有输入,那么真实的sql应该是

select * from a=:av and c=:cv and d = : dv 或与之等价的SQL

如select * from a=:av and 1=1 and c=:cv and d = : dv

当四个都不输入时,最终sql便是select * from a或是与之等价的SQL。

换而言之,select * from a=:av and b=:bv and c=:cv and d = : dv 写成后,用户并不希望修改它或是写多份备用,而是希望程序通过输入参数而动态调整SQL。

 

思索:

用正则表达式知道条件对应的模式,如果输入了就将值部分替换为真实数,没有输入就把该项变成1=1.

比如用户指定av=1,cv=3,dv=4,bv没有输入,那么最终的SQL是:

select * from a=1 and 1=1 and c=3 and d = 4

 

实现:

复制代码
import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Test {
    public static void main(String[] args) {
        String rawSql="select * from a=:av and b=:bv and c=:cv and d = : dv";
        System.out.println("rawSql="+rawSql);
        
        // 模拟输入的条件
        Map<String,String> map=new HashMap<>();
        map.put("av", "1");
        //map.put("bv", "2");// 被屏蔽的表示此条件未输入
        map.put("cv", "3");
        map.put("dv", "4");
        
        Pattern pattern=Pattern.compile("((\\w+)\\s*[=]\\s*)([:]\\s*(\\w+))");
        Matcher matcher=pattern.matcher(rawSql);
        boolean found=matcher.find();
        
        StringBuilder sb=new StringBuilder();
        while(found) {
            String value=matcher.group(4);
            
            if(map.containsKey(value)) {
                matcher.appendReplacement(sb, matcher.group(1)+map.get(value));
            }else {
                matcher.appendReplacement(sb, "1=1");
            }
            
            found=matcher.find();
        }
        matcher.appendTail(sb);
        
        String finalSql=sb.toString();
        System.out.println("finalSql="+finalSql);
    }
}
复制代码

输出:

rawSql=select * from a=:av and b=:bv and c=:cv and d = : dv
finalSql=select * from a=1 and 1=1 and c=3 and d = 4

-END-

posted @   逆火狂飙  阅读(181)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2013-09-23 【Canvas】在canvas中画出一张图片
2013-09-23 【MySQL】将浮点数保持几位小数,尾数舍入的Format函数
2013-09-23 从Date类型字段获得当日周几的DAYNAME函数
2013-09-23 【Java/Image】给指定路径下图片反色并加上当前日期形式的水印
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示