代碼如下:
--獲取表的count信息
select count(*) from T with(nolock)
--獲取特定值的count信息
select count(*) from T with(nolock)
where v = '--value'
--獲取表'T'的count信息
select count(*) from T with(nolock)
SELECT * from T --獲取表T
Where P
我們先來試著給出一個簡單的匹配:
代碼如下:
\-\-[^\r\n]*$
你會發(fā)現(xiàn),它連第二條的SQL也匹配到了,這是不對的??雌饋?,我們應該排除"'"里面的, 我們再來改改:
代碼如下:
\-\-[^\'\r\n]{0,}$
還是不對,這下雖然第二條的SQL沒有匹配,但連第三條的都不匹配了,看起來還是不對。
那到底怎么樣才能真正匹配到所有的SQL注釋呢?
首先我們來總結一下SQL注釋的一些特點:
1. 以--開頭
2. 注釋的內容,應該不會被包含在一對''之內
3. 注釋應該只會在最后,前面可以可選的出現(xiàn)一些語句
好了,收集到了這些之后,我們最終的SQL注釋的語法也出來了:
代碼如下:
\-\-([^\'\r\n]{0,}(\'[^\'\r\n]{0,}\'){0,1}[^\'\r\n]{0,}){0,}$
這一下,四條SQL的注釋全匹配到了,正則表達式太強大了吧。
這個SQL語句有一個小小問題,就是后面不能有一個單的單引號存在,否則就會匹配有問題。(因為人們的習慣對于這種分隔符默認是成雙出現(xiàn)的,這個小問題其實也是可以忽略的)
更多信息請查看IT技術專欄