SQL:运算符

算术运算符

与许多其他语言类似(好吧,我们在这里承认SQL是一门语言)
(+)、减(-)、乘(*)、除(/)和取模(%,MOD)运算

运算注意事项:

  1. 一个整数类型的值对整数进行加法和减法操作,结果还是一个整数;
  2. 一个整数类型的值对浮点数进行加法和减法操作,结果是一个浮点数;
  3. 在Java中,+的左右两边如果有字符串,那么表示字符串的拼接。但是在MySQL中+只表示数
    值相加。如果遇到非数值类型,先尝试转成数值,如果转失败,就按0计算。(补充:MySQL
    中字符串拼接要使用字符串函数CONCAT()实现)
  4. 除法默认得到的是浮点数,不管是整数相除还是浮点数相除,不管能够除的尽。
  5. 在数学运算中,0不能用作除数,在MySQL中,一个数除以0为NULL。

比较运算符

符号类型运算符与非符号类型运算符

符号运算符

等号运算符(=,<=>)

在mysql中,=用作了判断,那么在mysql中,赋值符号是:=

  1. 不安全等号运算(=)
    如果等号两边的值、字符串或表达式都为字符串,则MySQL会按照字符串进行比较,其比较的是每个字符串中字符的ANSI编码是否相等。
    如果等号两边的值都是整数,则MySQL会按照整数来比较两个值的大小。
    如果等号两边的值一个是整数,另一个是字符串,则MySQL会将字符串转化为数字进行比较。
    如果等号两边的值、字符串或表达式中有一个为NULL,则比较结果为NULL。
    缺点:沾上null,输出结果就为null。
  2. 安全等号运算(<=>)
    使用安全等于运算符时,两边的操作数的值都为NULL时,返回的结果为1而不是NULL,其他
    返回结果与等于运算符相同。
    注意在Windows系统下,比较字符串大小时是不区分大小写的,如需区分比较,则需要使用binary将字符串转化为二进制字符进行比较
SELECT BINARY 'a' = 'A';
不等号运算符(<>,!=)

不等于运算符(<>和!=)用于判断两边的数字、字符串或者表达式的值是否不相等,如果不相等则返回1,相等则返回0。不等于运算符不能判断NULL值。如果两边的值有任意一个为NULL,或两边都为NULL,则结果为NULL。

非符号运算符

空运算符(IS NULL或者ISNULL)

判断一个值是否为NULL,如果为NULL则返回1,否则返回 0。

 SELECT NULL IS NULL, ISNULL(NULL), ISNULL('a'), 1 IS NULL;
非空运算符(IS NOT NULL)

判断一个值是否不为NULL,如果不为NULL则返回1,否则返回0。

SELECT NULL IS NOT NULL, 'a' IS NOT NULL, 1 IS NOT NULL;
最大、最小值运算符(LEAST,GREATEST)
  1. 最小值运算符(LEAST)
    当参数是整数或者浮点数时,LEAST将返回其中最小的值;当参数为字符串时,返回字
    母表中顺序最靠前的字符;当比较值列表中有NULL时,不能判断大小,返回值为NULL。
SELECT LEAST(1,0,2),LEAST('b','a','c'),
  1. 最大值运算符(GREAST)
    其中,n表示参数列表中有n个值。当有
    两个或多个参数时,返回值为最大值。假如任意一个自变量为NULL,则GREATEST()的返回值为NULL。
SELECT GREATEST(1,0,2), GREATEST('b','a','c'), GREATEST(1,NULL,2);

缺点:如果我想求出某个列的最小、最大值,这个函数是求不出来的,因为不可能把所有的值,一个一个的放进去,要解决这个问题必须要利用后面的聚合函数MIN()或者MAX()。

区间运算符(BETWEEN AND、IN、NOT IN)
  1. BETWEEN AND运算符
 SELECT 1 BETWEEN 0 AND 1, 10 BETWEEN 11 AND 12, 'b' BETWEEN 'a' AND 'c';
  1. 在这里插入代码片IN 运算符
    IN运算符用于判断给定的值是否是IN列表中的一个值,如果是则返回1,否则返回0。如果给定的值为NULL,或者IN列表中存在NULL,则结果为NULL
 SELECT 'a' IN ('a','b','c'), 1 IN (2,3), NULL IN ('a','b'), 'a' IN ('a', NULL);
  1. NOT IN运算符
    NOT IN运算符用于判断给定的值是否不是IN列表中的一个值,如果不是IN列表中的一
    个值,则返回1,否则返回0。
SELECT 'a' NOT IN ('a','b','c'), 1 NOT IN (2,3);
字符串匹配运算符(LIKE、ESCAPE、REGEXP)
  1. LIKE运算符
    LIKE运算符主要用来匹配字符串,通常用于模糊匹配,如果满足条件则返回1,否则返回
    0。如果给定的值或者匹配条件为NULL,则返回结果为NULL。
%”:匹配0个或多个字符。
“_”:只能匹配一个字符。## 逻辑运算符
-- 以S为首字母的字符串
SELECT first_name
FROM employees
WHERE first_name LIKE 'S%';
-- 第二个字母为o的
SELECT last_name
FROM employees
WHERE last_name LIKE '_o%';

总结起来就是如果 like
2. ESCAPE运算符
回避特殊符号的是:使用转义符\或者使用选定的字符,但是需要用ESCAPE关键词标明

SELECT job_id
FROM jobs
WHERE job_id LIKE ‘IT\_%;
-- 或者使用ESCAPE
SELECT job_id
FROM jobs
WHERE job_id LIKE ‘IT$_%escape ‘$‘;

注意\运算符不能与ESCAPE同时使用。
例如下面得到语句是会报错的

SELECT job_id
FROM jobs
WHERE job_id LIKE 'IT\$_%' ESCAPE '\';
  1. REGEXP运算符
-- expr REGEXP 匹配条件
SELECT 'shkstart' REGEXP '^s', 'shkstart' REGEXP 't$', 'shkstart' REGEXP 'hk';
(1)‘^’匹配以该字符后面的字符开头的字符串。
(2)‘$’匹配以该字符前面的字符结尾的字符串。
(3)‘.’匹配任何一个单字符。
(4)“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”或“b”或“c”。为了命名字符的范围,使用一
个‘-’。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。
(5)‘*’匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的‘x’字符,“[0-9]*”匹配任何数量的数字,而“*”匹配任何数量的任何字符。

逻辑运算符

与java基本类似,但是每一种都有符号类型与非符号类型,还要注意null值得参与处理
&&—AND
!—NOT
|| —OR
XOR

位运算符

与java几乎一致

使用正则表达式进行查询

SQL:运算符_第1张图片
LIKE运算符也可以匹配指定的字符串,但与REGEXP不同,LIKE匹配的字符串如果在文本中间出现,则找不到它,相应的行也不会返回。REGEXP在文本内进行匹配,如果被匹配的字符串在文本中出现,REGEXP将会找到它,相应的行也会被返回。

 SELECT * FROM fruits WHERE f_name REGEXP '^b';
 SELECT * FROM fruits WHERE f_name REGEXP 'y$';
 -- 在fruits表中,查询f_name字段值包含字符串“on”的记录,SQL语句如下:
  SELECT * FROM fruits WHERE f_name REGEXP 'on';
 -- 在fruits表中,查询f_name字段值包含字符串“on”或者“ap”的记录,SQL语句如下:
SELECT * FROM fruits WHERE f_name REGEXP 'on|ap';

你可能感兴趣的:(SQL那些事,sql,mysql,数据库)