• 关于sql通配符检索问题-【.NET】


    确定给定的字符串是否与指定的模式匹配。模式可以包含常规字符和通配符字符。模式匹配过程中,常规字符必须与字符串中指定的字符完全匹配。然而,可使用字符串的任意片段匹配通配符。与使用 = 和 != 字符串比较运算符相比,使用通配符可使 LIKE 运算符更加灵活。如果任何参数都不属于字符串数据类型,Microsoft® SQL Server™ 会将其转换成字符串数据类型(如果可能)。

    语法
    match_expression [ NOT ] LIKE pattern [ ESCAPE escape_character ]

    参数
    match_expression 任何字符串数据类型的有效 SQL Server 表达式。
    patternmatch_expression 中的搜索模式,可以包含下列有效 SQL Server 通配符

    1 % 包含零个或更多字符的任意字符串
    示例:WHERE title LIKE '%computer% ' 将查找处于书名任意位置的包含单词 computer 的所有书名。

    2 _(下划线) 任何单个字符
    示例:WHERE au_fname LIKE '_ean ' 将查找以 ean 结尾的所有 4 个字母的名字(Dean、Sean 等)。

    3 [] 指定范围中的任何单个字符
    示例:WHERE au_lname LIKE '[C-P]arsen ' 将查找以arsen 结尾且以介于 C 与 P 之间的任何单个字符开始的 作者姓氏,例如,Carsen、Larsen、Karsen 等

    4 [^] 不属于指定范围中的任何单个字符,与 [] 相反
    示例:WHERE au_lname LIKE 'de[^l]% ' 将查找以 de 开始且其后的字母不为 l 的所有作者的姓氏。

    一 使用 like 的模式匹配:
    在搜索Datetime类型时,建议使用like .
    LIKE 支持 ASCII 模式匹配和 Unicode 模式匹配。当所有参数,包括 match_expression、pattern 和 escape_character(如果有)都是 ASCII 字符数据类型时,将执行 ASCII 模式匹配。如果其中任何参数属于 Unicode 数据类型,则所有参数将被转换为 Unicode 并执行 Unicode 模式匹配。当对 Unicode 数据(nchar 或 nvarchar 数据类型)使用 LIKE 时,尾随空格是有意义的。但是对于非 Unicode 数据,尾随空格没有意义。Unicode LIKE 与 SQL-92 标准兼容。ASCII LIKE 与 SQL Server 的早期版本兼容

    二 使用 % 通配符


    例如,此查询将显示数据库中所有的系统表,因为它们都以字母 sys 开始:
    SELECT TABLE_NAME
    FROM INFORMATION_SCHEMA.TABLES
    WHERE TABLE_NAME LIKE 'sys% '
    若要查阅非系统表的所有对象,请使用 NOT LIKE 'sys% '。如果共有 32 个对象且 LIKE 找到 13 个与模式匹配的名称,则 NOT LIKE 将找到 19 个与 LIKE 模式不匹配的对象

    三 使用escape字句的模式匹配


    可搜索包含一个或多个特殊通配符的字符串。例如,customers 数据库中的 discounts 表可能存储含百分号 (%) 的折扣值。若要搜索作为字符而不是通配符的百分号,必须提供 ESCAPE 关键字和转义符。例如,一个样本数据库包含名为 comment 的列,该列含文本 30%。若要搜索在 comment 列中的任何位置包含字符串 30% 的任何行,请指定由 WHERE comment LIKE '%30!%% ' ESCAPE '! ' 组成的 WHERE 子句。如果不指定 ESCAPE 和转义符,SQL Server 将返回所有含字符串 30 的行。

    下例使用 ESCAPE 子句和转义符查找 mytbl2 表的 c1 列中的精确字符串 10-15%

    USE pubs
    GO
    IF EXISTS(SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES
    WHERE TABLE_NAME = 'mytbl2 ')
    DROP TABLE mytbl2
    GO
    USE pubs
    GO
    CREATE TABLE mytbl2
    (
    c1 sysname
    )
    GO
    INSERT mytbl2 VALUES ( 'Discount is 10-15% off ')
    INSERT mytbl2 VALUES ( 'Discount is .10-.15 off ')
    GO
    SELECT c1
    FROM mytbl2
    WHERE c1 LIKE '%10-15!% off% ' ESCAPE '! '
    GO


    四 使用 [] 通配符

    下例查找姓为 Carson、Carsen、Karson 或 Karsen 的作者所在的行。
    USE pubs
    SELECT au_lname, au_fname, phone
    FROM authors
    WHERE au_lname LIKE '[CK]ars[eo]n '
    ORDER BY au_lname ASC, au_fname ASC 

  • 相关阅读:
    偶对学习C#以及理解.Net平台的一些看法(二,Junior Bibliography)
    聊聊编程那些破事0.Prehistory
    偶对学习C#以及理解.Net平台的一些看法(一,Prerequisites)
    [转帖]c#.net常用函数列表
    一个编程小题目引发的思考(上)
    geoTools学习笔记001(简介)
    ArcGIS Server 10安装配置(JAVA)
    ARCGIS中label(标注)和Annotation(注记
    JSTL入门开发包详解
    基于C/S的网盘设计(JAVA) 网盘源码实现部分功能
  • 原文地址:https://www.cnblogs.com/vijozsoft/p/3497796.html
Copyright © 2020-2023  润新知