ORACLE中的SQL操作符

时间:2021-09-28 15:45:18

SQL操作符可以对字符串或者值列表,值范围以及空值进行模式匹配,进而来限定查询返回的行
(1)LIKE:匹配字符串中的模式

  • 下划线(_):匹配指定位置的一个字符
  • 百分号(%):匹配从指定位置开始的任意多个字符

比如:

SELECT NAME FROM STUDEN WHERE NAME LIKE'%三'--表示从STUDENT表中查找姓名最后一个汉字是三的学生姓名,在三之前可以有任意多的字符
SELECT NAME FORM STUDENT WHERE NAME LIKE '_三'--表示从STUDENT表中查找学生姓名,该学生姓名第二个字符是三

如果需要对字符串中的实际的下划线或者百分号字符进行搜索,可以使用ESCAPE选项来标识这些字符。
(2)NOT LIKE:与上面意思相反
(3)IN:匹配值列表
可以使用IN来判断某个值是否在值得列表中,比如

SELECT * FROM customers WHERE customer_id IN(1,2,3,5);

(4)NOT IN:与上面意思相反
如果列表中包含空值,那么NOT IN就会返回false
(5)BETWEEN:匹配值范围
用来检验某个值是否在指定的值得区间范围内

SELECT * FROM STUDENT WHERE studentNum BETWEEN 120701140201 AND 120701140229

(6)NOT BETWEEN:与上面意思相反
检索那些不在指定范围内的值。
(7)IS NULL:匹配空值
(8)IS NOT NULL:与上面意思相反
(9)IS NAN:匹配NAN这个特殊值,“非数字”
(10)IS NOT NAN:与上面意思相反
(11)IS INFINITE:匹配BINARY_FLOAT和BINARY_DOUBLE中的“无穷”值。
(12)IS NOT INFINITE:与上面意思相反