欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用正則表達(dá)式匹配tsql注釋語句

 更新時間:2014年02月25日 14:47:18   作者:  
我相信接觸過SQL Server數(shù)據(jù)庫的很多朋友都知道,它是以"--"開頭來進(jìn)行注釋的,下面的方法是使用正則表達(dá)式匹配tsql注釋語句的方法,大家參考使用吧

讓我們來看一些例子:

復(fù)制代碼 代碼如下:

--獲取表的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

我們先來試著給出一個簡單的匹配:

復(fù)制代碼 代碼如下:

\-\-[^\r\n]*$

你會發(fā)現(xiàn),它連第二條的SQL也匹配到了,這是不對的??雌饋?,我們應(yīng)該排除"'"里面的, 我們再來改改:
復(fù)制代碼 代碼如下:

\-\-[^\'\r\n]{0,}$

還是不對,這下雖然第二條的SQL沒有匹配,但連第三條的都不匹配了,看起來還是不對。

那到底怎么樣才能真正匹配到所有的SQL注釋呢?

首先我們來總結(jié)一下SQL注釋的一些特點:

1. 以--開頭

2. 注釋的內(nèi)容,應(yīng)該不會被包含在一對''之內(nèi)

3. 注釋應(yīng)該只會在最后,前面可以可選的出現(xiàn)一些語句

好了,收集到了這些之后,我們最終的SQL注釋的語法也出來了:

復(fù)制代碼 代碼如下:

\-\-([^\'\r\n]{0,}(\'[^\'\r\n]{0,}\'){0,1}[^\'\r\n]{0,}){0,}$

這一下,四條SQL的注釋全匹配到了,正則表達(dá)式太強大了吧。

這個SQL語句有一個小小問題,就是后面不能有一個單的單引號存在,否則就會匹配有問題。(因為人們的習(xí)慣對于這種分隔符默認(rèn)是成雙出現(xiàn)的,這個小問題其實也是可以忽略的)

相關(guān)文章

最新評論