对于SQL Server中查找字符串的子串这个问题,许多人第一个想法是使用like,没错,但是如果出现如下的情况使用like就无法解决:
查找一个表中的列中的数据是否是另一个表中一个列的数据的子串,这时由于两个列都是变量名,所以无法使用like来做模糊匹配
下面我们对这个问题的整体做一个描述:
1. 子串是字符串值
1.1 使用like进行模糊匹配
这种方式是通用的,在各种支持SQL
的数据库中都能使用,所以也是最容易想到的。
实例如下:
select * from user where username like '李%'
找到用户表中姓李的所用用户。
1.2 使用PATINDEX內建函数进行模糊匹配
这个内置函数是SQL Server
独有的,不能用在别的数据库上,使用这个函数在指定字符串中寻找指定模式的子串,并返回子串在指定字符串中的位置。
参数:
- 第一个入参为要查找的字符串模糊匹配字符串,使用”%”设置模糊匹配
- 第二个入参为被搜索的字符串表达式
返回值:
- 如果在指定的字符串中搜索到要查找的字符串,则返回对应子串在指定字符串的开始位置
- 如果没有搜索到则返回0
实例:
select * from user where PATINDEX('李%', username) > 0
找到用户表中姓李的所用用户。
2. 子串是变量名
这时需要使用SQL Server
中的内置函数CHARINDEX
,使用这个函数是在指定字符串中寻找子串,并返回子串在指定字符串中的位置。
参数:
- 第一个入参为要查找的字符串子串表达式
- 第二个入参为被搜索的字符串表达式
- 第三个入参为搜索的起始位置,也可以不指定,不指定时从头开始查找
返回值:
- 如果在指定的字符串中搜索到要查找的字符串,则返回对应子串在指定字符串的开始位置
- 如果没有搜索到则返回0
实例:
select * from user u1, vip v1 where CHARINDEX(u1.username, v1.username) > 0