MySql010——检索数据:过滤数据(使用LIKE操作符结合%、_通配符)

前提:使用《MySql006——检索数据:基础select语句》中创建的products表
在这里插入图片描述

一、LIKE操作符

  1. LIKE 子句中使用百分号 %字符来表示任意字符串,使用_表示任意单个字符,类似于UNIX或正则表达式中的星号 *。
  2. 如果没有使用百分号 %, LIKE 子句与等号 = 的效果是一样的。

二、百分号(%)通配符

%表示任意字符串。

2.1、检索以指定字符串开头的行

所有以词jet起头的产品,可使用以下SELECT语句:

SELECT 
    vend_id, prod_name, prod_price
FROM
    products
WHERE
    prod_name LIKE 'jet%';	-- 只要prod_name字段的值开头是jet,后面是什么都可以

MySql010——检索数据:过滤数据(使用LIKE操作符结合%、_通配符)_第1张图片

2.2、检索以指定字符串结尾的行

SELECT 
    vend_id, prod_name, prod_price
FROM
    products
WHERE
    prod_name LIKE '%anvil';-- 只要prod_name字段的值结尾是anvil,前面是什么都可以

在这里插入图片描述

2.3、检索以指定字符串开头和结尾的行

SELECT 
    vend_id, prod_name, prod_price
FROM
    products
WHERE
    prod_name LIKE 'je%00';-- 只要prod_name字段的值以je开头且00结尾,中间是什么都可以

在这里插入图片描述

2.4、检索包含指定字符串的行

SELECT 
    vend_id, prod_name, prod_price
FROM
    products
WHERE
    prod_name LIKE '%stick%';-- 只要prod_name字段的值包含stick,前后是什么都可以

在这里插入图片描述

三、下划线(_)通配符

下划线只匹配单个字符而不是多个字符。

SELECT 
    vend_id, prod_name, prod_price
FROM
    study.products
WHERE
    prod_name LIKE '_ ton anvil'; -- 下划线的位置可以是任意单个字符

在这里插入图片描述

你可能感兴趣的:(#,MySql,mysql,数据库,sql)