SQL LIKE 子句用于使用通配符运算符将值与类似值进行比较.有两个通配符与LIKE运算符一起使用.
百分号(%)
下划线(_)
百分号表示零个,一个或多个字符.下划线表示单个数字或字符.这些符号可以组合使用.
%和_的基本语法如下 :
SELECT FROM table_name WHERE列LIKE'XXXX%' 或 SELECT FROM table_name WHERE列LIKE'%XXXX%' 或 SELECT FROM table_name WHERE列LIKE'XXXX_' 或 SELECT FROM table_name WHERE列LIKE'_XXXX' 或 SELECT FROM table_name WHERE列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 | +----+----------+-----+-----------+----------+
以下是一个示例,它将显示来自的所有记录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 | +----+----------+-----+-----------+----------+