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

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

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

讓我們來(lái)看一些例子:

復(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

我們先來(lái)試著給出一個(gè)簡(jiǎn)單的匹配:

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

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

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

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

還是不對(duì),這下雖然第二條的SQL沒(méi)有匹配,但連第三條的都不匹配了,看起來(lái)還是不對(duì)。

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

首先我們來(lái)總結(jié)一下SQL注釋的一些特點(diǎn):

1. 以--開(kāi)頭

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

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

好了,收集到了這些之后,我們最終的SQL注釋的語(yǔ)法也出來(lái)了:

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

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

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

這個(gè)SQL語(yǔ)句有一個(gè)小小問(wèn)題,就是后面不能有一個(gè)單的單引號(hào)存在,否則就會(huì)匹配有問(wèn)題。(因?yàn)槿藗兊牧?xí)慣對(duì)于這種分隔符默認(rèn)是成雙出現(xiàn)的,這個(gè)小問(wèn)題其實(shí)也是可以忽略的)

相關(guān)文章

最新評(píng)論