溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2021-12-01 11:17:36 來(lái)源:億速云 閱讀:211 作者:柒染 欄目:數(shù)據(jù)庫(kù)

如何使用正則表達(dá)式匹配注釋tsql語(yǔ)句,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

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

 代碼如下:

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

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

 代碼如下: \-\-[^\r\n]*$

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

 代碼如下: \-\-[^\'\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í)也是可以忽略的)

看完上述內(nèi)容,你們掌握如何使用正則表達(dá)式匹配注釋tsql語(yǔ)句的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI