需求:
輸入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