sql server charindex函数和patindex函数详解(转)
charindex和patindex函数常常用来在一段字符中搜索字符或字符串。假如被搜索的字符中包含有要搜索的字符,那么这两个函数返回一个非零的整数,这个整数是要搜索的字符在被搜索的字符中的开始位数。patindex函数支持使用通配符来进行搜索,然而charindex不支持通配符。接下来,我们逐个分析这两个函数。
怎样使用charindex函数
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。
接下来,我们看这个charindex命令:
charindex(7.0, microsoft sql server 2000)
在这个例子中,charindex返回零,因为字符串“7.0” 不能在“microsoft sql server”中被找到。
接下来通过两个例子来看看怎样使用charindex函数来解决实际的t-sql问题。
第一个例子,假设您要显示northwind数据库customer表前5行联系人列的last name。这是前5行数据
contactname
------------------------------
maria anders
ana trujillo
antonio moreno
thomas hardy
christina berglund
您能够看到,customname包含客户的first name和last name,他们之间被一个空格隔开。我用charindx函数确定两个名字中间空格的位置。通过这个方法,我们能够分析contactname列的空格位置,这样我们能够只显示这个列的last name部分。这是显示northwind的customer表前5行last name的记录!
select top 5 substring(contactname,charindex(‘’ ,contactname)+1 ,len(contactname)) as [last name] from northwind.dbo.customers
SELECT SUBSTRING('lipasdas lip asdfa',CHARINDEX('lip','lipasdas lip asdfa')+3,2)
下面是这个命令输出的结果。
last name
------------------------------
anders
trujillo
moreno
hardy
berglund
charindex函数找到first name和last name之间的空格,所以substring函数能够分开contactname列,这样就只有last name被选出。我在charindex函数返回的整数上加1,这样last name不是从空格开始。
在第二个例子中,即如说您要计算记录中,某一个字段包含特定字符的任何记录数。charindex函数能够方便的解决您的问题。计算northwind.dbo.customer表中addresses字段中包含单词road或他的缩写rd的记录数,选择语句类似这样:
select count(*) from northwind.dbo.customers
where charindex(rd,address) > 0 or charindex(road,address)> 1
怎样使用patindex函数
patindex函数返回字符或字符串在另一个字符串或表达式中的起始位置,patindex函数支持搜索字符串中使用通配符,这使patindex函数对于变化的搜索字符串很有价值。patindex函数的命令如下:
patindex ( %pattern% , expression )
pattern是您要搜索的字符串,expression是被搜索的字符串。一般情况下expression是个表中的一个字段,pattern的前后需要用“%”标记,除非您搜索的字符串在被收缩的字符串的最前面或最后面。
和charindex函数相同,patindex函数返回搜索字符串在被搜索字符串中的起始位置。假如有这样一个patindex函数:
patindex(%bc%,abcd)
这个patindex函数返回的结果是2,这和charindex函数相同。这里的%标记告诉patindex函数去找字符串“bc”,不管被搜索的字符串中在“bc”的前后有多少字符!
假如您想知道被搜索字符串是否由特定的字符串开始,您能够省去前面的%标记。patinded函数就要这样写:
patindex(ab%,abcd)
这个命令执行的结果返回1,表示搜索的字符串“ab”在被搜索的字符串中“abcd”被找到。
使用通配符能够编辑比我以上举得简单例子复杂得多的搜索字符串。假如说您要确定一个字符串是否包含字母a和z,更有任何数字,这个parindex函数命令可能像这样:
patindex(%[a,z,0-9]%[a,z,0-9]%[a,z,0-9]%,xyzabc123)
注意在上面这个例子中的搜索字符部分使用了很多的通陪符。察看sql server联机丛书能够获得更多关于通佩符的信息。接下来,我们用两个例子来看patindex和select怎么联合起来使用。
假设您想要找出northwind.dbo.categories表中description字段中是包含单词“bread”或“Bread”的任何记录,那么选择语句就可能是这样:
select description from northwind.dbo.categories
where patindex(%[b,b]read%,description) > 0
这里我用通配符来确定大写和小写的“b”。我在notthwind数据库中执行这个脚本后,得到下面的结果:
description
--------------------------------------------------------
desserts, candies, and sweet breads
breads, crackers, pasta, and cereal
这是再用另外一个额外的通配符来查找一些记录的例子。这个例子是怎样选出上面的查询结果中,description字段的第二子字母不是“e”的纪录。
select description from northwind.dbo.categories
where patindex(%[b,b]read%,description) > 0
and patindex(_[^e]%,description) = 1
通过在条件语句中增加一个使用^通配符的patindex函数,我们能够过滤掉“dessert, candies, and sweet breads”这条记录。上面的查询结果只有一条记录。
description
--------------------------------------------------------
breads, crackers, pasta, and cereal
总结
您现在能够发现charindex和patindex搜索字符串时的区分了吧。patindex函数支持使用通配符,能够用在很多有变化的查找中。而charindex不能够。根据您自己不同的情况,这两个函数对您在sql server中的字符串的搜索、控制、分析很有帮助。
sql server charindex函数和patindex函数详解(转)的更多相关文章
- SQL Server日期时间格式转换字符串详解
本文我们主要介绍了SQL Server日期时间格式转换字符串的相关知识,并给出了大量实例对其各个参数进行对比说明,希望能够对您有所帮助. 在SQL Server数据库中,SQL Server日期时间格 ...
- SQL Server 默认跟踪(Trace)捕获事件详解
SQL Server 默认跟踪 -- 捕获事件详解 哪些具体事件默认跟踪文件能够捕获到? --returns full list of events SELECT * FROM sys.trace_e ...
- SQL Server 2008 CDC增量变更捕获详解
1 背景: 随着公司业务的成长,数据量也随之的不断增长.随之而来的问题是在做ETL的时候,时间花费也越来越长.为了节省时间开销,我们只想要更新最新的数据,不想要把公司历年所有的数据都进行处理.这种情况 ...
- Microsoft SQL Server中的事务与并发详解
本篇索引: 1.事务 2.锁定和阻塞 3.隔离级别 4.死锁 一.事务 1.1 事务的概念 事务是作为单个工作单元而执行的一系列操作,比如查询和修改数据等. 事务是数据库并发控制的基本单位,一条或者一 ...
- SQL Server日期时间格式转换字符串详解 (详询请加qq:2085920154)
在SQL Server数据库中,SQL Server日期时间格式转换字符串可以改变SQL Server日期和时间的格式,是每个SQL数据库用户都应该掌握的.本文我们主要就介绍一下SQL Server日 ...
- SQL Server NULL值用法及处理详解
用法如下: 1.如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录,这意味着该字段将以 NULL 值保存. 2.NULL 用作未知的或不适用的值的占位符. 3.定 ...
- SQL SERVER 2012安装配置说明(多图详解)
1. 优先安装软件 1. net framework3.5. 2. 在安装SQL SERVER 2012前需要3.5的支持.在WIN 2012系统可以在系统管理的添加角色和功能中安装,如下将[.NET ...
- SQL Server 连接字符串和身份验证详解
SQL Server .NET Data Provider 连接字符串包含一个由一些属性名/值对组成的集合.每一个属性/值对都由分号隔开. PropertyName1=Value1; ...
- SQL Server 2012 Enterprise Edition安装过程详解(包含每一步设置的含义)
一.启动安装程序,点击“安装”选项卡,选择“全新SQL Server独立安装或向现有安装添加功能”.(首次安装数据库系统或向现有数据库系统添加功能,均选择此选项) 二.随后,安装程序进行“安装程序支持 ...
- SQL Server解析XML数据的方法详解
--下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <Info Name=&q ...
随机推荐
- 交换机的MAC地址作用
交换机的MAC地址在交换机进行数据交换时是没有作用的,因为交换机并不对转发的数据帧进行拆包重封装. 如果只是完成数据帧交换,则可以不要MAC地址(仅指二层交换机,三层交换机完成路由功能自然每个端口得有 ...
- [Python Debug] How to install external python package? MAC系统下的xgboost安装
从昨天晚上开始安装xgboost,经历了各种稀奇古怪的错误,终于现在程序可以跑起来了.整个过程对python编译环境,路径设置,package安装方法有了一定了解,当然还有一些疑惑,所以姑且做个记录. ...
- 洛谷——P1690 贪婪的Copy
P1690 贪婪的Copy 题目描述 Copy从卢牛那里听说在一片叫yz的神的领域埋藏着不少宝藏,于是Copy来到了这个被划分为个区域的神地.卢牛告诉了Copy这里共有个宝藏,分别放在第Pi个(1&l ...
- Java 的几种版本
1. Java ME Java ME(Java 2 Micro Edition),是为机顶盒.移动电话和PDA之类嵌入式消费电子设备提供的Java语言平台,包括虚拟机和一系列标准化的Java API. ...
- VS2010 MFC中 创建文件夹及文件判空的方法
1. MFC中 创建文件夹的方法如下: CString strFolderPath = "./Output"; //判断路径是否存在 if(!PathIsDirectory(str ...
- EasyMvc入门教程-高级控件说明(20)表格控件
表单与表格是信息化系统里很常见的控件,EasyMvc提供了简单的数据绑定方式(基于Json),看下面的示例: 准备的接口地址代码如下:(该接口适用以下所有例子) public IActionResu ...
- Elite Container DELPHI下的一个轻量级IoC对象容器
一.简介: Elite Container是DELPHI下的一个轻量级IoC对象容器(IoC:Inverse of Control,反转控制).它是参考了Java中的Spring框架(主要是配置文件的 ...
- k8s学习(一)——kubectl与api-server之间的交互核心过程
k8s的架构是用户使用kubectl工具对虚拟机资源进行各种各样的控制和定制. 而kubectl本身并不包含对其核心资源的访问与控制.而是通过http通信与api-server进行交互实现资源的管理. ...
- Eclipse Memory Analyzer安装
转载:http://www.jianshu.com/p/3b3c3a914724 1.下载地址:Eclipse Memory Analyzer Open Source Project 2.点击进入 ...
- BFC简析
一.BOX模型 box是CSS中布局的基本单位,而不同类型的box,会参与不同的Formatting Context(一个决定如何渲染文档的容器),box内的元素会以不同的方式渲染. block-le ...