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

对于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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值