【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-
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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】给指定路径下图片反色并加上当前日期形式的水印