【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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM