SQL Server 中查找字符串中的子串

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lmy86263/article/details/52336190

对于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
阅读更多

没有更多推荐了,返回首页