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函数详解(转)的更多相关文章

  1. SQL Server日期时间格式转换字符串详解

    本文我们主要介绍了SQL Server日期时间格式转换字符串的相关知识,并给出了大量实例对其各个参数进行对比说明,希望能够对您有所帮助. 在SQL Server数据库中,SQL Server日期时间格 ...

  2. SQL Server 默认跟踪(Trace)捕获事件详解

    SQL Server 默认跟踪 -- 捕获事件详解 哪些具体事件默认跟踪文件能够捕获到? --returns full list of events SELECT * FROM sys.trace_e ...

  3. SQL Server 2008 CDC增量变更捕获详解

    1 背景: 随着公司业务的成长,数据量也随之的不断增长.随之而来的问题是在做ETL的时候,时间花费也越来越长.为了节省时间开销,我们只想要更新最新的数据,不想要把公司历年所有的数据都进行处理.这种情况 ...

  4. Microsoft SQL Server中的事务与并发详解

    本篇索引: 1.事务 2.锁定和阻塞 3.隔离级别 4.死锁 一.事务 1.1 事务的概念 事务是作为单个工作单元而执行的一系列操作,比如查询和修改数据等. 事务是数据库并发控制的基本单位,一条或者一 ...

  5. SQL Server日期时间格式转换字符串详解 (详询请加qq:2085920154)

    在SQL Server数据库中,SQL Server日期时间格式转换字符串可以改变SQL Server日期和时间的格式,是每个SQL数据库用户都应该掌握的.本文我们主要就介绍一下SQL Server日 ...

  6. SQL Server NULL值用法及处理详解

    用法如下: 1.如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录,这意味着该字段将以 NULL 值保存. 2.NULL 用作未知的或不适用的值的占位符. 3.定 ...

  7. SQL SERVER 2012安装配置说明(多图详解)

    1. 优先安装软件 1. net framework3.5. 2. 在安装SQL SERVER 2012前需要3.5的支持.在WIN 2012系统可以在系统管理的添加角色和功能中安装,如下将[.NET ...

  8. SQL Server 连接字符串和身份验证详解

    SQL Server .NET Data Provider 连接字符串包含一个由一些属性名/值对组成的集合.每一个属性/值对都由分号隔开.          PropertyName1=Value1; ...

  9. SQL Server 2012 Enterprise Edition安装过程详解(包含每一步设置的含义)

    一.启动安装程序,点击“安装”选项卡,选择“全新SQL Server独立安装或向现有安装添加功能”.(首次安装数据库系统或向现有数据库系统添加功能,均选择此选项) 二.随后,安装程序进行“安装程序支持 ...

  10. SQL Server解析XML数据的方法详解

    --下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <Info Name=&q ...

随机推荐

  1. codevs——1048 石子归并 (区间DP)

    时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解       题目描述 Description 有n堆石子排成一列,每堆石子有一个重量w[i], 每次合并可以合并 ...

  2. POJ 3373 Changing Digits 记忆化搜索

    这道题我是看了别人的题解才做出来的.题意和题解分析见原文http://blog.csdn.net/lyy289065406/article/details/6698787 这里写一下自己对题目的理解. ...

  3. UVA 10827 Maximum sum on a torus 最大矩阵和

    题目链接:UVA - 10827 题意描述:给出一个n*n矩阵,把第一行和最后一行粘一起,把第一列和最后一列粘一起,形成一个环面,求出这个环面中最大的矩阵和. 算法分析:首先复制n*n这个矩阵,形成由 ...

  4. Android Retrofit使用教程(二)

    上一篇文章讲述了Retrofit的简单使用,这次我们学习一下Retrofit的各种HTTP请求. Retrofit基础 在Retrofit中使用注解的方式来区分请求类型.比如@GET("&q ...

  5. 【spring boot logback】日志logback 生成日志文件在本项目下,而不在指定的日志文件目录下/指定日志文件到达最大值后不按照配置进行切割

    原本的日志文件配置如下: <?xml version="1.0" encoding="UTF-8"?> <configuration scan ...

  6. php 报错等级

    定义和用法:    error_reporting() 设置 PHP 的报错级别并返回当前级别. 函数语法:    error_reporting(report_level) 如果参数 level 未 ...

  7. java编译命令工具javac

    Reads Java class and interface definitions and compiles them into bytecode and class files. Synopsis ...

  8. MySQL具体解释(14)----------事务处理

    前言:前一篇文章关于事务处理的博文没有写清楚,读起来非常晦涩.非常难理解,所以有整理了一些资料,帮助理解.见谅! 关于MySQL事务处理学习记 START TRANSACTION COMMIT ROL ...

  9. Vmware+gdb调试Linux内核——工欲善其事,必先利其器

    今天我最终忍受不了qemu的低速跟不可理喻的各种bug,開始寻找新的调试内核的方法.然后想到了Vmware,那么成熟的虚拟机怎么可能调试不了内核.于是尝试了一番,发现结果很的棒!所以立刻奋笔疾书.把这 ...

  10. UBUNTU : Destination Host Unreachable

    介绍我的系统的搭建的方式: WIN7 64 + VMWARE STATION,方式是进行桥接的方式.最近突然出现了问题,Ubuntu ping 外网或者 PING WIN 7 的时候,出现 Desti ...