国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

使用正則表達式匹配tsql注釋語句

2024-08-31 01:01:58
字體:
來源:轉載
供稿:網友

讓我們來看一些例子:

復制代碼 代碼如下:


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


你會發現,它連第二條的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語句有一個小小問題,就是后面不能有一個單的單引號存在,否則就會匹配有問題。(因為人們的習慣對于這種分隔符默認是成雙出現的,這個小問題其實也是可以忽略的)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 富裕县| 滕州市| 景德镇市| 砀山县| 台前县| 长治县| 汕头市| 竹山县| 黎平县| 河北区| 句容市| 武冈市| 桑植县| 惠州市| 郴州市| 霍邱县| 玛沁县| 阳曲县| 西和县| 英山县| 珠海市| 桐乡市| 同心县| 出国| 仙游县| 闻喜县| 胶南市| 瑞金市| 上思县| 雷山县| 许昌市| 苏尼特左旗| 蒲城县| 延川县| 巢湖市| 广元市| 白银市| 治县。| 曲麻莱县| 怀安县| 阜宁县|