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
下面是这个命令输出的结果。
           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中的字符串的搜索、控制、分析很有帮助。

转载于:https://www.cnblogs.com/shuai/archive/2010/05/25/1743278.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/381028.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Win10最新批量激活

W269N-WFGWX-YVC9B-4J6C9-T83GX 先来说下使用激活码使用方法: 1、同时按下Win键X,然后选择命令提示符(管理员) 2、在命令提示符中依次输入: slmgr.vbs /upk (此时弹出窗口显未“已成功卸载了产品密钥”…

dosbox 伪指令dd为什么会报错_什么是SQL函数?为什么使用SQL函数可能会带来问题?...

本文已收录GitHub,更有互联网大厂面试真题,面试攻略,高效学习资料等函数在计算机语言的使用中贯穿始终,在 SQL 中我们也可以使用函数对检索出来的数据进行函数操作,比如求某列数据的平均值,或者求字符串的长…

最新webshell大合集

收集与整理了各种webshell,以便在日后的项目中做Webshell检测训练。 https://github.com/tennc/webshell 各种webshell集合 https://github.com/ysrc/webshell-sample webshell样本 https://github.com/xl7dev/WebShell Webshell && Backdoor Collection…

JavaScript 参考教程(二)——转载

对象化编程 JavaScript 是使用“对象化编程”的,或者叫“面向对象编程”的。所谓“对象化编程”,意思是把 JavaScript 能涉及的范围划分成大大小小的对象,对象下面还继续划分对象直至非常详细为止,所有的编程都以对象为出发点&…

centos7 docker删除端口映射_容器Docker详解

概述基本概念Docker是一个开源的应用容器引擎,基于Go语言并遵从Apache2.0协议开源。Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。容器是完全使用沙箱机制&a…

深入解析结构化异常处理(SEH) - by Matt Pietrek

尽管以前写过一篇SEH相关的文章《关于SEH的简单总结》, 但那真的只是皮毛,一直对Windows异常处理的原理似懂非懂, 看了下面的文章 ,一切都豁然开朗. 1997年文章,Windows技术的根一直没变:http://www.micr…

IE Mobie6清除浮动

看来已经有很多中window的毒了,平时操作系统是window,现在还好多人用window mobie,看来已经习惯了window的使用方式。做前端开发,有个IE 6已经够受的了,没想到半路杀出个IE Mobie。期待IE6被埋葬的一天。 做几个页面&a…

@requestbody 接受int参数_C++之指针作为函数参数

C 允许您传递指针给函数&#xff0c;只需要简单地声明函数参数为指针类型即可。下面的实例中&#xff0c;我们传递一个无符号的 long 型指针给函数&#xff0c;并在函数内改变这个值&#xff1a;#include <iostream> #include <ctime>using namespace std; void ge…

hash函数查找和ASL计算

Hash表的“查找成功的ASL”和“查找不成功的ASL” ASL指的是 平均查找时间 关键字序列&#xff1a;&#xff08;7、8、30、11、18、9、14&#xff09; 散列函数&#xff1a; H(Key) (key x 3) MOD 7 装载因子&#xff1a; 0.7 处理冲突&#xff1a;线性探测再散列法 查…

Jquery CheckBox全选方法

方法如下&#xff1a; function CheckAll(val) {$("input[namechkJob]").each(function() {this.checked val;});$("#chkAll").attr("checked", val);//设定全选按钮状态}val 该参数传递的是全选按钮的选择状态 namechkJob 这个为列表中的check…

c++怎么将文件中的数据读出并赋值给字符串_web前端开发过程中如何写JavaScript程序?...

script标签使用< script >< /script >src : 外联script 标签(立即调用,不能在该标签内写代码)< script >// 在标签内书写内容< /script >< script srcjavascript.js >// 这里面不能写任何内容< /script >一切准备就绪&#xff0c;让我们从…

简美电子相册

下载地址&#xff1a;微客互联 转载于:https://www.cnblogs.com/Witkey/archive/2010/06/10/1755755.html

强制进程结束(内核函数)

windows给我们结束进程的函数是PsTerminateSystemThread function&#xff0c;通过反汇编我们可以看到PsTerminateSystemThread 调用了未导出的函数PspTerminateThreadByPointer &#xff0c;然后这个函数又调用了APC和PspExitThread函数对进程实现强制结束。

3说明书_知行翻译:做化妆品说明书翻译时,这3点需要谨记

经过20多年的迅猛发展&#xff0c;被称为“美丽经济”的中国化妆品产业已经取得非常大的成就&#xff0c;在这20多年里&#xff0c;中国化妆品产业从小到大&#xff0c;从弱到强&#xff0c;从简单粗放到科技领先&#xff0c;已经逐步成为全世界最大的新兴市场&#xff0c;很多…

拉拢中小网站 淘宝百度暗战升级...

拉拢中小网站 淘宝百度暗战升级... 重庆晚报 讯 近日&#xff0c;大量淘宝联盟站长反映其网站在百度搜索结果大幅缩水&#xff0c;疑遭集体封杀。百度的理由是“清扫垃圾页面”。迟迟未表态的淘宝近日对前者进行了公开回应。至此&#xff0c;淘宝跟百度之间为拉拢中小网站的暗战…

转——idapython import site failed

打开IDA出现这个错误提示&#xff0c;问题根源是IDA找不到python&#xff0c;安装2.7版本的python并设置%PYTHONHOME%变量为python安装目录就可以了 如果已经安装了python可以在命令行下用echo %PYTHONHOME%看看配置有没有问题

matlab中将数据保存为txt文件_matlab中将数据输出保存为txt格式文件的方法 (1)

总结网上各大论坛&#xff0c;主要有三种方法。第一种方法&#xff1a;save(最简单基本的)具体的命令是&#xff1a;用save *.txt -ascii xx为变量*.txt为文件名,该文件存储于当前工作目录下&#xff0c;再打开就可以打开后,数据有可能是以指数形式保存的.例子&#xff1a;a [1…

有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数

有1、2、3、4个数字&#xff0c;能组成多少个互不相同且无重复数字的三位数&#xff1f; 步骤&#xff1a;先定一个函数&#xff0c;把数据储存在一个列表&#xff0c;然后传入函数中就行了 代码 def threeDN(a):组成多少个互不相同且无重复数字的三位数num0for i1 in a:for…

.Net Remoting(基本操作) - Part.2 (转)

Remoting 构架 1.客户端(客户应用程序) 客户端的处理包含三个基本的组成部分&#xff0c;代理(Proxy)、格式器(Formatter) 和 通道(Channel)。 2.服务端(宿主应用程序) 服务端主要由 通道(Channel)、格式器(Formatter)、Stack Builder组成。 在服务端&#xff0c;宿主程序保持着…

转载——CVE-2019-0807

译文声明 本文是翻译文章&#xff0c;文章原作者mcafee&#xff0c;文章来源&#xff1a;securingtomorrow.mcafee.com 原文地址&#xff1a;https://securingtomorrow.mcafee.com/other-blogs/mcafee-labs/rdp-stands-for-really-do-patch-understanding-the-wormable-rdp-v…