Sql Server charIndex和patIndex 使用介绍

it2022-07-01  137

使用环境:确定某一字符串中是否包含在某一段文字中

使用介绍:CHARINDEX和PATINDEX函数常常用来在一段字符中搜索字符或者字符串。如果被搜索的字符中包含有要搜索的字符,那么这两个函数返回一个非零的整数,这个整数是要搜索的字符在被搜索的字符中的开始位数。PATINDEX函数支持使用通配符来进行搜索,然而CHARINDEX不支持通佩符(这两者的区别)。

运用例子:

1:charindex 的使用

CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用格式:CHARINDEX ( eXPression1 , expression2 [ , start_location ] )

Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。CHARINDEX函数返回是一个整数,返回的整数是要找的字符串在被找的字符串中的位置。如果CHARINDEX没有找到要找的字符串,那么函数整数“0”

select charindex('sql','sql server 2008') // return 1select charindex('2009','sql server 2008') // return 0

假设你要显示Northwind数据库Customer表前5行联系人列的Last Name。这是前5行数据Maria AndersAna TrujilloAntonio MorenoThomas HardyChristina 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------------------------------ AndersTrujilloMorenoHardyBerglund

CHARINDEX函数找到First Name和Last Name之间的空格,所以SUBSTRING函数可以分开ContactName列,这样就只有Last Name被选出。我在CHARINDEX函数返回的整数上加1,这样Last Name不是从空格开始。

在第二个例子中,即如说你要计算记录中,某一个字段包含特定字符的所有记录数。CHARINDEX函数可以方便的解决你的问题。计算 Northwind.dbo.Customer表中Addresses字段中包含单词Road或者它的缩写Rd的记录数,选择语句类似这样:

SELECT count(*) from Northwind.dbo.CustomersWHERE CHARINDEX('Rd',Address) > 0 or CHARINDEX('Road',Address)> 1

2:patindex 的使用

PATINDEX函数返回字符或者字符串在另一个字符串或者表达式中的起始位置,PATINDEX函数支持搜索字符串中使用通配符,这使PATINDEX函数对于变化的搜索字符串很有价值。PATINDEX函数的命令如下:

PATINDEX ( '%pattern%' , expression )

Pattern是你要搜索的字符串,expression是被搜索的字符串。一般情况下expression是一个表中的一个字段,pattern的前后需要用“%”标记,除非你搜索的字符串在被收缩的字符串的最前面或者最后面。和CHARINDEX函数一样,PATINDEX函数返回搜索字符串在被搜索字符串中的起始位置。

PATINDEX('

转载请注明原文地址: https://win8.8miu.com/read-1499328.html

最新回复(0)