SQL LIKE 运算符:用法、示例和通配符解释

复制代码
    SQL中的<code>LIKE</code>运算符用于在WHERE</code>子句中搜索列中的指定模式。通常与<code>LIKE,运算符一起使用的有两个通配符:</p>
  • 百分号 % 代表零个、一个或多个字符。

  • 下划线 _ 代表一个单个字符。

    以下是LIKE运算符的用法和示例:

    示例

    选择所有以字母 "a" 开头的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE 'a%';
    
       

    语法

    LIKE运算符的一般语法如下:

    复制代码
      
      
       
        
    * SELECT column1, column2, ...
    
        
    * FROM table_name
    
        
    * WHERE columnN LIKE pattern;
    
       

    演示数据库

    以下是示例中使用的 Customers 表的一部分:

    CustomerID CustomerName ContactName Address City PostalCode Country
    1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
    2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
    3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico
    4 Around the Horn Thomas Hardy 120 Hanover Sq. London WA1 1DP UK
    5 Berglunds snabbköp Christina Berglund Berguvsvägen 8 Luleå S-958 22 Sweden

    下划线 _ 通配符

    下划线 _ 通配符代表一个单个字符。它可以是任何字符或数字,但每个 _ 代表一个且仅代表一个字符。

    示例

    返回以 'L' 开头,然后是一个通配符字符,然后是 'nd',然后是两个通配符字符的城市中的所有客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE city LIKE 'L_nd__';
    
       

    百分号 % 通配符

    百分号 % 通配符代表任意数量的字符,甚至是零个字符。

    示例

    返回包含字母 'L' 的城市中的所有客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE city LIKE '%L%';
    
       

    以...开头

    要返回以特定字母或短语开头的记录,请在字母或短语的末尾添加 %

    示例

    返回所有以 'La' 开头的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE 'La%';
    
       

    以...结尾

    要返回以特定字母或短语结尾的记录,请在字母或短语的开头添加 %

    示例

    返回所有以 'a' 结尾的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE '%a';
    
       

    包含

    要返回包含特定字母或短语的记录,请在字母或短语的前后添加 %

    示例

    返回包含短语 'or' 的所有客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE '%or%';
    
       

    组合通配符

    任何通配符,如 %_,都可以与其他通配符一起使用。

    示例

    返回以 "a" 开头且至少为 3 个字符长的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE 'a__%';
    
       

    示例

    返回第二个位置有 "r" 的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE CustomerName LIKE '_r%';
    
       

    不使用通配符

    如果没有指定通配符,短语必须精确匹配才能返回结果。

    示例

    返回所有来自西班牙的客户:

    复制代码
      
      
       
        
    * SELECT * FROM Customers
    
        
    * WHERE Country LIKE 'Spain';
    
       

    LIKE运算符非常有用,因为它允许您执行模糊搜索,查找与特定模式匹配的数据。

相关推荐
LaughingZhu1 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫1 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
廿一夏1 小时前
MySql存储引擎与索引
数据库·sql·mysql
小鹏linux2 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水3 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger3 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
lzhdim3 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
涵涵(互关)3 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态3 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态3 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态