MySQL函数简介 2

6.5 条件判断函数

条件判断函数也被称为控制流程函数,根据满足的条件的不同,执行相应的流程,Mysql中进行条件判断的有IF,IFNULL,和CASE。

6.5.1 IF(expr,v1,v2)函数

IF(expr,v1,v2)如果表达式expr是true(expr<>0 and expr<>NULL),则IF()的返回值为v1,否则返回v2。IF()的返回值为数字或字符串值。
SELECT IF(1>2,2,3),IF(1<2,'YES','NO'),IF(STRCMP('TEST','TEST1'),'NO','YES');

image.png

如果v1或者v2中只有一个明确是NULL,则IF()函数的结果类型为非NULL表达式结果类型。

6.5.2 IF(v1,v2)函数

IFNULL(v1,v2)加入v1不为NULL,则IFNULL()的值为v1,否则返回值为v2,IFNULL的返回值是数字或者字符串。
SELECT IFNULL(1,2),IFNULL(NULL,10),IFNULL(1/0,'WRONG');

image.png

注意:1/0的结果为空,因此IFNULL(1/0,'wrong')返回wrong.

6.5.3 CASE函数

CASE expr WHEN v1 THEN[WHEN v2 THEN r2][ELSE rn] END.
该函数表示,如果expr值等于某个vn,则返回对应THEN后面的结果,如果与所有值都不相同则返回ELSE后面的rn。
SELECT
    CASE 5
WHEN 1 THEN
    'one'
WHEN 2 THEN
    'two'
ELSE
    'more'
END;

image.png

CASE后面的值为2,与第二条分支语句WHEN后面的值相等,因此返回'two'。
SELECT
    CASE
WHEN 1 < 0 THEN
    'true'
ELSE
    'false'
END;

image.png

1<0结果为false,因此函数返回值为ELSE后的'false'

6.6 系统信息函数

Mysql中的系统信息有,数据库的版本号、当前用户名和连接数、系统字符集、最后一个自动生成的ID值。

6.6.1 获取mysql中的版本号,连接数,数据库名的函数。

SELECT VERSION()

image.png

返回指示mysql服务器版本的字符串,这个字符串使用utf8字符集。
SELECT CONNECTION_ID()

image.png

SHOW PROCESSLIST;

image.png

6.6.2 获取用户名的函数

USER(),CURRENT_USER,CURRENT_USER(),SYSTEM_USER()和SESSION_USER()这几个函数返回当前被mysql服务器验证的用户名和主机名组合。一般情况下这几个函数返回值是相同的。
SELECT USER(),CURRENT_USER(),SYSTEM_USER();

image.png

6.6.3 获取字符串的字符集和排序方式的函数

SELECT
CHARSET('abc'),
CHARSET(CONVERT('abc' USING latin1)),
CHARSET(VERSION())

image.png

       SELECT
       collation('abc'),
       COLLATION(CONVERT('abc' USING utf8))

image.png

6.6.4 获取最后一个自动生成的ID值的函数

LAST_INSERT_ID自动返回最后一个INSERT或者UPDATE为AUTO_INCREMENT列设置的第一个发生的值。
  1. 一次插入一条记录

INSERT INTO worker VALUES(NULL,'jimy');
INSERT INTO worker VALUES(NULL,'tony');
SELECT LAST_INSERT_ID();

image.png

  1. 一次同时插入多条
INSERT INTO worker VALUES(NULL,'kevry'),(NULL,'LILI'),(NULL,'miaomiao');

image.png

6.7 加密函数

6.7.1 加密函数PASSWORD(str)

6.7.2 加密函数MD5(str)

6.7.3 加密函数ENCODE(str,pswd_str)

6.7.4 解密函数DECODE(crypt_str,pswd_str)

你可能感兴趣的:(mysql)