mssql查询中用charindex函数代替instr函数

mssql的sql查询语句是无法执行instr函数的

instr适用于access数据库

mssql的sql查询语句用CHARINDEX(str1 ,str2 [开始搜索的位置,可以不写]) 代替 instr

Access中用:

instr( "bcad ", "a ")

SQL Server中用:

select charindex( 'a ', 'bcad ')

select charindex( 'c ', 'abcd ')--在abcd中查出c的位置,结果为3

select charindex( 'c ', 'abcd ',2)--在abcd中从第2个字符开始查出c的位置,结果为2

在SQL中有两个函数可以实现:

1.CHARINDEX 返回字符串中指定表达式的起始位置。

CHARINDEX ( 搜索字符串, 被搜索字符串 [ ,搜索开始位置] )

如果搜索开始位置省略,将从被搜索字符串的第一个位置开始,否则从指定的位置开始

2.PATINDEX 返回指定表达式中某模式第一次出现的起始位置;

PATINDEX ( '%搜索字符串% ' , 被搜索字符串)

此函数的功能与CHARINDEX基本相同,不同之处在于此函数在搜索时可以采用通配符的方式进行搜索,详细操作方法可以参考SQL的联机帮助

3.注意:两个函数搜索时,搜索字符串不区分大小写

posted @ 2010-06-20 12:57  许鄞韬  阅读(3598)  评论(0编辑  收藏  举报