sql語句中charindex的用法 可用於截取字符串


使用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 沒有完全精確匹配的




參照:

beeone   

[SQL]sql語句中charindex的用法


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM