我们已经讨论了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 | +----+----------+-----+-----------+----------+