SQL - 通配符运算符

我们已经讨论了SQL LIKE运算符,它用于使用通配符运算符将值与类似值进行比较.

SQL支持两个通配符运算符和LIKE运算符这些在下表中有详细解释.

Sr.No.Wildcard&描述
1

百分号(%)

匹配一个或多个字符.

注意 :  MS Access使用星号(*)通配符而不是百分号(%)通配符.

2

下划线(_)

匹配一个字符.

注意 :  MS Access使用问号(?)而不是下划线(_)来匹配任何一个字符.

百分号表示零个,一个或多个字符.下划线表示单个数字或字符.这些符号可以组合使用.

语法

'%'和'_'运算符的基本语法如下.

SELECT FROM table_name
WHERE column LIKE 'XXXX%'

or 

SELECT FROM table_name
WHERE column LIKE '%XXXX%'

or

SELECT FROM table_name
WHERE column LIKE 'XXXX_'

or

SELECT FROM table_name
WHERE column LIKE '_XXXX'

or

SELECT FROM table_name
WHERE column LIKE '_XXXX_'

您可以使用AND或OR运算符组合N个条件.这里,XXXX可以是任何数字或字符串值.

示例

下表有一些示例显示WHERE部分具有不同的LIKE子句使用'%'和'_'运算符.

Sr.No.声明&描述
1

WHERE SALARY LIKE'200%'

查找任何以200开头的值.

2

WHERE SALARY LI'%200%'

查找任何位置有200的任何值.

3

SALERE LIKE'_00%'

查找在第二和第三位置有00的任何值.

4

WHERE SALARY LIKE'2 _%_%'

查找任何以2开头并且长度至少为3个字符的值.

5

WHERE SALARY LIKE'%2'

查找以2结尾的任何值.

    6

在哪里等待'_2%3'

查找任何在第二个位置有2且以3结尾的值.

    7

在哪里SALAL'2 ___ 3'

查找任何值以5位数字开头,以2开头,以3结尾.

让我们来看看例如,考虑具有以下记录的CUSTOMERS表.

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

以下代码块是一个示例,它将显示所有t他从CUSTOMERS表中记录SALARY以200开头.

 
 SQL> SELECT * FROM CUSTOMERS 
 WHERE SALARY LIKE'200%';

这会产生以下结果.

+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
+----+----------+-----+-----------+----------+