您好,登錄后才能下訂單哦!
如何使用正則表達式匹配注釋tsql語句,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
讓我們來看一些例子:
代碼如下:
--獲取表的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
我們先來試著給出一個簡單的匹配:
代碼如下: \-\-[^\r\n]*$
你會發現,它連第二條的SQL也匹配到了,這是不對的。看起來,我們應該排除"'"里面的, 我們再來改改:
代碼如下: \-\-[^\'\r\n]{0,}$
還是不對,這下雖然第二條的SQL沒有匹配,但連第三條的都不匹配了,看起來還是不對。
那到底怎么樣才能真正匹配到所有的SQL注釋呢?
首先我們來總結一下SQL注釋的一些特點:
1. 以--開頭
2. 注釋的內容,應該不會被包含在一對''之內
3. 注釋應該只會在最后,前面可以可選的出現一些語句
好了,收集到了這些之后,我們最終的SQL注釋的語法也出來了:復制代碼 代碼如下: \-\-([^\'\r\n]{0,}(\'[^\'\r\n]{0,}\'){0,1}[^\'\r\n]{0,}){0,}$
四條SQL的注釋全匹配到了,正則表達式太強大了吧。
這個SQL語句有一個小小問題,就是后面不能有一個單的單引號存在,否則就會匹配有問題。(因為人們的習慣對于這種分隔符默認是成雙出現的,這個小問題其實也是可以忽略的)
看完上述內容,你們掌握如何使用正則表達式匹配注釋tsql語句的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。