使用CHARINDEX和PATINDEX函數來搜索文字列和字符串。這兩個函數是如何運轉的,解釋他們的區別。同時提供一些例子,通過這些例子,你可以可以考慮使用這兩個函數來解決很多不同的字符搜索的問題。
CHARINDEX和PATINDEX函數常常用來在一段字符中搜索字符或者字符串。如果被搜索的字符中包含有要搜索的字符,那么這兩個函數返回一個非零的整數,這個整數是要搜索的字符在被搜索的字符中的開始位數。PATINDEX函數支持使用通配符來進行搜索,然而CHARINDEX不支持通佩符。接下來,我們逐個分析這兩個函數。
如何使用CHARINDEX函數
CHARINDEX函數返回字符或者字符串在另一個字符串中的起始位置。CHARINDEX函數調用方法如下:
CHARINDEX ( expression1 , expression2 [ , start_location ] )
Expression1是要到expression2中尋找的字符中,start_location是CHARINDEX函數開始在expression2中找expression1的位置。
CHARINDEX函數返回一個整數,返回的整數是要找的字符串在被找的字符串中的位置。假如CHARINDEX沒有找到要找的字符串,那么函數整數“0”。讓我們看看下面的函數命令執行的結果:
CHARINDEX(’SQL’, ’Microsoft SQL Server’)
這個函數命令將返回在“Microsoft SQL Server”中“SQL”的起始位置,在這個例子中,CHARINDEX函數將返回“S”在“Microsoft SQL Server”中的位置11。
接下來,我們看這個CHARINDEX命令:
CHARINDEX(’7.0’, ’Microsoft SQL Server 2000’)
在這個例子中,CHARINDEX返回零,因為字符串“7.0” 不能在“Microsoft SQL Server”中被找到。接下來通過兩個例子來看看如何使用CHARINDEX函數來解決實際的T-SQL問題。
第一個例子,假設你要顯示Northwind數據庫Customer表前5行聯系人列的Last Name。這是前5行數據
ContactName
------------------------------
Maria Anders
Ana Trujillo
Antonio Moreno
Thomas Hardy
Christina Berglund
你可以看到,CustomName包含客戶的First Name和Last Name,它們之間被一個空格隔開。我用CHARINDX函數確定兩個名字中間空格的位置。通過這個方法,我們可以分析ContactName列的空格位置,這樣我們可以只顯示這個列的last name部分。這是顯示Northwind的Customer表前5行last name的記錄!
select top 5 substring(ContactName,charindex(’ ’,ContactName)+1 ,
len(ContactName)) as [Last Name] from Northwind.dbo.customers
下面是這個命令輸出的結果。
Last Name
------------------------------
Anders
Trujillo
Moreno
Hardy
Berglund
-
patindex(pattern,expression) 精確匹配,完全匹配1,不完全匹配0
例如:patindex('aa','aa') 返回1 完全匹配
patindex('aa','aab') 返回0 不完全匹配
-
patindex(%pattern%,expression)模糊匹配,返回從第幾位開始匹配
-
例如:patindex('%aa%','ssaaa') 返回3 模糊從第三位開始匹配
patindex('%aa','ssddaa') 返回5 模糊從第五位開始匹配
patindex('%aa','ssddaaa') 返回6 模糊從第六位開始匹配
patindex('%aa%','ssddaaa') 返回5 模糊從第五位開始匹配
-
charindex(pattern,expression)精確匹配,返回第一個滿足條件的下標
例如:charindex(aa,aas) 返回1 從第一位開始精確匹配
charindex(aa,saas) 返回2 從第二位開始精確匹配
charindex(aa,saaas) 返回2 從第二位開始精確匹配
charindex(aa,sas) 返回0 沒有完全精確匹配的
參照:
