代碼如下:
--獲取表的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
我們先來試著給出一個(gè)簡(jiǎn)單的匹配:
代碼如下:
\-\-[^\r\n]*$
你會(huì)發(fā)現(xiàn),它連第二條的SQL也匹配到了,這是不對(duì)的。看起來,我們應(yīng)該排除"'"里面的, 我們?cè)賮砀母?
代碼如下:
\-\-[^\'\r\n]{0,}$
還是不對(duì),這下雖然第二條的SQL沒有匹配,但連第三條的都不匹配了,看起來還是不對(duì)。
那到底怎么樣才能真正匹配到所有的SQL注釋呢?
首先我們來總結(jié)一下SQL注釋的一些特點(diǎn):
1. 以--開頭
2. 注釋的內(nèi)容,應(yīng)該不會(huì)被包含在一對(duì)''之內(nèi)
3. 注釋應(yīng)該只會(huì)在最后,前面可以可選的出現(xiàn)一些語句
好了,收集到了這些之后,我們最終的SQL注釋的語法也出來了:
代碼如下:
\-\-([^\'\r\n]{0,}(\'[^\'\r\n]{0,}\'){0,1}[^\'\r\n]{0,}){0,}$
這一下,四條SQL的注釋全匹配到了,正則表達(dá)式太強(qiáng)大了吧。
這個(gè)SQL語句有一個(gè)小小問題,就是后面不能有一個(gè)單的單引號(hào)存在,否則就會(huì)匹配有問題。(因?yàn)槿藗兊牧?xí)慣對(duì)于這種分隔符默認(rèn)是成雙出現(xiàn)的,這個(gè)小問題其實(shí)也是可以忽略的)
更多信息請(qǐng)查看IT技術(shù)專欄
2025國(guó)考·省考課程試聽報(bào)名