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

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

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

2020-07-25 12:59:48
字體:
供稿:網(wǎng)友

讓我們來看一些例子:

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

我們先來試著給出一個簡單的匹配:

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

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

你會發(fā)現(xiàn),它連第二條的SQL也匹配到了,這是不對的。看起來,我們應(yīng)該排除"'"里面的, 我們再來改改:
復(fù)制代碼 代碼如下:

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

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

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

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

1. 以--開頭

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

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

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

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

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 奉新县| 益阳市| 宾阳县| 太康县| 阜宁县| 敦煌市| 沁源县| 贵州省| 东城区| 同仁县| 隆子县| 玛曲县| 花莲县| 民丰县| 西和县| 黔江区| 南阳市| 湖南省| 额尔古纳市| 囊谦县| 什邡市| 扬中市| 墨玉县| 唐海县| 黄冈市| 安阳市| 双牌县| 罗山县| 高淳县| 通化市| 蛟河市| 乌拉特中旗| 浮梁县| 鸡西市| 孟州市| 延长县| 宁化县| 察雅县| 安远县| 漳平市| 蒲城县|