• [转载] [SQL] patindex 详解


    PATINDEX
    返回指定表达式中某模式第一次出现的起始位置;如果在全部有效的文本和字符数据类型中没有找到该模式,则返回零。
    语法
    PATINDEX ( '%pattern%' , e­xpression )
    参数
    pattern
    一个字符串。可以使用通配符,但 pattern 之前和之后必须有 % 字符(搜索第一个和最后一个字符时除外)。pattern 是短字符数据类型类别的表达式。
    e­xpression
    一个表达式,通常为要在其中搜索指定模式的列,e­xpression 为字符串数据类型类别。
    返回类型
    int
    注释
    PATINDEX 对 text 数据类型很有用;除 IS NULL、IS NOT NULL 和 LIKE(这些是 Where 子句中对 text 类型有效的仅有的其它比较运算)外,PATINDEX 也可用于 Where 子句中。

    -----------------------------------------

    例一:
    找出Northwind.dbo.Categories表中Description字段中是包含单词“Bread”或“bread”的所有记录,那么选择语句就可能是这样:

    Select Description from Northwind.dbo.Categories
    Where patindex('%[b,B]read%',description) > 0

    PATINDEX 中可以使用通配符来确定大写和小写的“b”

    例二:
    找出Northwind.dbo.Categories表中Description字段中是包含单词“Bread”或“bread”,且第二子字母不是“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”这条记录。上面的查询结果只有一条记录。


    PATINDEX与CHARINDEX

    PATINDEX函数支持使用通配符,可以用在很多有变化的查找中。而CHARINDEX不可以。根据你自己不同的情况,这两个函数对你在SQL Server中的字符串的搜索、控制、分析很有帮助。
  • 相关阅读:
    CSS3盒模型display初探(display:box/display:flex)
    css伪元素研究(::before/::after)
    css后代选择器(div.class中间不带空格)
    css选择器(选择<div>内所有<p>元素)
    text-indent无效解决方案
    控制div位于最上层
    gulp用途
    Webpack打包工具实时更新操作(启用观察者模式)
    CLR/.NET/C#/Visual Studio/ASP.NET各版本之间的关系(转)
    前端打包/自动化构建工具:fis3
  • 原文地址:https://www.cnblogs.com/RobotTech/p/1277385.html
Copyright © 2020-2023  润新知