sql中charindex的用法


轉自:https://www.cnblogs.com/beeone/p/3621743.html


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
復制代碼


免責聲明!

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



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