【Java/Regexp】用正则表达式验证sql是否select语句

需求:

输入sql,判断其是否查询语句,检查规则是:select开头,sql中不允许有insert、delete和update的出现。

程序:

复制代码
package test;

public class SelectMatch {
    public static void main(String[] args) {
        String[] arr= {    "select * from dual",
                        " Select f1,f2 from tb",
                        "select * from tb for update",
                        "insert into tb value(1,2)",
                        " update tb set f1=1 where f2=2",
                        "   delete from tb where id=10",
                        " SELET a,b,c from tb where d=5",
                        "SELect a.*,b.* from a left join b on a.id=b.aid",
                        " select A from B | delete",
                        "   selectsysdate from dual",
                        " select insert from tb",};
        
        for(String text:arr) {
            if(isSelect(text)) {
                System.out.println(text);
            }
        }
    }
    
    private static boolean isSelect(String sql) {
        return sql.matches("^(?i)(\\s*)(select)(\\s+)(((?!(insert|delete|update)).)+)$");
    }
}
复制代码

输出:

select * from dual
 Select f1,f2 from tb
SELect a.*,b.* from a left join b on a.id=b.aid

正则表达式分析:

^...$ :将目标字符串从头检查到尾,毋庸多言;

(?i):不区分大小写

(\\s*):select之前允许有0个或多个空格

(select):空格或开头后就必须有select

(\\s+): select之后必须跟至少一个空格

(?!(insert|delete|update)). :上面的空格后的任意字符,前方不得有insert、delete、update之一

((?!(insert|delete|update)).)+ :“任意字符,前方不得有insert、delete、update之一”这个模式,可以重复一到多次。

END

PS:如果对?!正则式陌生,可以参考:https://www.cnblogs.com/heyang78/p/15720928.html

posted @   逆火狂飙  阅读(4787)  评论(9编辑  收藏  举报
编辑推荐:
· 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)
历史上的今天:
2019-12-22 【java/oralce/sql】往一张仅有id,名称,创建时间三个字段的表中插入百万数据需要多久?1分26秒
2019-12-22 [oracle/java/sql]用于上十万批量数据插入Oracle表的Java程序
2019-12-22 [SQL]用于提取组内最新数据,左连接,内连接,not exist三种方案中,到底谁最快?
2017-12-22 【高中数学/极值问题】一条长为L的绳子,一面靠墙,另外三边组成矩形,问此矩形最大面积能是多少?
2014-12-22 Java取得操作系统的临时目录
2014-12-22 将ByteArrayOutputStream类型变量中的数据存储到文件中
2014-12-22 【高中数学/基本不等式】已知:x,y 皆大于0,且xy-x-y=3 求:2x+y的最小值?
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示