使用正則表達式匹配tsql注釋語句
來源:易賢網(wǎng) 閱讀:1127 次 日期:2014-05-12 15:21:10
溫馨提示:易賢網(wǎng)小編為您整理了“使用正則表達式匹配tsql注釋語句”,方便廣大網(wǎng)友查閱!

代碼如下:

--獲取表的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也匹配到了,這是不對的。看起來,我們應(yīng)該排除"'"里面的, 我們再來改改:

代碼如下:

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

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

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

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

1. 以--開頭

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

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

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

代碼如下:

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

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

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

更多信息請查看IT技術(shù)專欄

更多信息請查看數(shù)據(jù)庫
易賢網(wǎng)手機網(wǎng)站地址:使用正則表達式匹配tsql注釋語句
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇剩?/div>
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)