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。例如:
select charindex('a',username) fromz_user
patindex ( %pattern% , expression )
pattern是您要搜索的字符串,expression是被搜索的字符串。一般情况下expression是个表中的一个字段,pattern的前后需要用“%”标记,除非您搜索的字符串在被收缩的字符串的最前面或最后面。
和charindex函数相同,patindex函数返回搜索字符串在被搜索字符串中的起始位置。假如有这样一个patindex函数:
patindex(%bc%,abcd)
这个patindex函数返回的结果是2,这和charindex函数相同。这里的%标记告诉patindex函数去找字符串“bc”,不管被搜索的字符串中在“bc”的前后有多少字符!例如:
select patindex('%a%',username) from z_user