MySQL学习笔记之常用函数

MySQL的常用函数

  一、条件判断函数
  # 1. if(表达式,值1,值2):若表达式成立(为true)则返回值1,否则返回值2
  mysql> select if(0=false,'true','false');
  +----------------------------+
  | if(0=false,'true','false') |
  +----------------------------+
  | true                       |
  +----------------------------+
  1 row in set (0.00 sec)
  mysql> select if(2=true,'true','false');
  +---------------------------+
  | if(2=true,'true','false') |
  +---------------------------+
  | false                     |
  +---------------------------+
  1 row in set (0.00 sec)

  mysql> select if(1=true,'true','false');
  +---------------------------+
  | if(1=true,'true','false') |
  +---------------------------+
  | true                      |
  +---------------------------+
  1 row in set (0.00 sec)

  +----------------------------------+
  | mid('我们都有一个家',1,2)        |
  +----------------------------------+
  | 我们                             |
  +----------------------------------+
  1 row in set (0.00 sec)

  # 2. ifnull(value1,value2):若值1的值为null,则返回value2,否则返回value1
  mysql> select ifnull(null,'null');
  +---------------------+
  | ifnull(null,'null') |
  +---------------------+
  | null                |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select ifnull('a',null);
  +------------------+
  | ifnull('a',null) |
  +------------------+
  | a                |
  +------------------+
  1 row in set (0.00 sec)
  
  # 3. case expr when val1 then expr1 [when val2 then expr2 ...] [else default] end
  如果表达式expr等于某个valn的值,则返回对应位置的then后面的exprn,若都不等于,则返回else后面的default默认值
  mysql> select case 5 when 2 then 'a' when 5 then 'b' else 'c' end;
  +-----------------------------------------------------+
  | case 5 when 2 then 'a' when 5 then 'b' else 'c' end |
  +-----------------------------------------------------+
  | b                                                   |
  +-----------------------------------------------------+
  1 row in set (0.00 sec)

  mysql> select case 0 when 2 then 'a' when 5 then 'b' else 'c' end;
  +-----------------------------------------------------+
  | case 0 when 2 then 'a' when 5 then 'b' else 'c' end |
  +-----------------------------------------------------+
  | c                                                   |
  +-----------------------------------------------------+
  1 row in set (0.00 sec)

  mysql> select case (select gender from students where id=1) when 1 then '男生' when 2 then '女生' else '未知' end;
  +-----------------------------------------------------------------------------------------------------------+
  | case (select gender from students where id=1) when 1 then '男生' when 2 then '女生' else '未知' end       |
  +-----------------------------------------------------------------------------------------------------------+
  | 男生                                                                                                      |
  +-----------------------------------------------------------------------------------------------------------+
  1 row in set (0.03 sec)

  mysql> select name,gender,case gender when 1 then '男生' when 2 then '女生' else '未知' end 性别 from students where id=1;
  +-----------+--------+--------+
  | name      | gender | 性别   |
  +-----------+--------+--------+
  | 包不同    |      1 | 男生   |
  +-----------+--------+--------+
  1 row in set (0.00 sec)

  mysql> select name,score,case when score>=90 then '良好' when score>=80 then '优秀' when score>=60 then '及格' else '不及格' end 成绩 from students where id=1;
  +-----------+-------+--------+
  | name      | score | 成绩   |
  +-----------+-------+--------+
  | 包不同    |    87 | 优秀   |
  +-----------+-------+--------+
  1 row in set (0.00 sec)

  二、字符函数
  # 1. concat(字符串1,字符串2,...):拼接多个字符串
  mysql> select concat('a','b','c');
  +---------------------+
  | concat('a','b','c') |
  +---------------------+
  | abc                 |
  +---------------------+
  1 row in set (0.00 sec)

  # 2. concat_ws(x,string,string):用x拼接字符串
  mysql> select concat_ws('、','a','b','c','d');
  +----------------------------------+
  | concat_ws('、','a','b','c','d')  |
  +----------------------------------+
  | a、b、c、d                       |
  +----------------------------------+
  1 row in set (0.00 sec)

  # 3. length(string):获取字符串字节长度
  mysql> select length('abcd');
  +----------------+
  | length('abcd') |
  +----------------+
  |              4 |
  +----------------+
  1 row in set (0.00 sec)

  mysql> select length('我');
  +---------------+
  | length('我')  |
  +---------------+
  |             3 |
  +---------------+
  1 row in set (0.00 sec)
  
  # 4. char_length(string):获取字符串字符长度
  mysql> select char_length('我');
  +--------------------+
  | char_length('我')  |
  +--------------------+
  |                  1 |
  +--------------------+
  1 row in set (0.00 sec)

  mysql> select char_length('abcd');
  +---------------------+
  | char_length('abcd') |
  +---------------------+
  |                   4 |
  +---------------------+
  1 row in set (0.00 sec)

  # 5. substring(string,开始索引(从1开始)/mid(string,开始索引(从1开始),截取的字符长度):截取字符串
  mysql> select substring('abcdefg',0);
  +------------------------+
  | substring('abcdefg',0) |
  +------------------------+
  |                        |
  +------------------------+
  1 row in set (0.00 sec)

  mysql> select substring('abcdefg',1);
  +------------------------+
  | substring('abcdefg',1) |
  +------------------------+
  | abcdefg                |
  +------------------------+
  1 row in set (0.00 sec)

  mysql> select substring('abcdefg',1,2);
  +--------------------------+
  | substring('abcdefg',1,2) |
  +--------------------------+
  | ab                       |
  +--------------------------+
  1 row in set (0.00 sec)

  mysql> select substring('我们都有一个家',1,2);
  +----------------------------------------+
  | substring('我们都有一个家',1,2)        |
  +----------------------------------------+
  | 我们                                   |
  +----------------------------------------+
  1 row in set (0.00 sec)

  # 6. instr(string1,string2):查找string2在string1中第一次出现的索引
  mysql> select instr('aaskjchaidquiw','a');
  +-----------------------------+
  | instr('aaskjchaidquiw','a') |
  +-----------------------------+
  |                           1 |
  +-----------------------------+
  1 row in set (0.00 sec)

  mysql> select instr('aaskjchaidquiw','b');
  +-----------------------------+
  | instr('aaskjchaidquiw','c') |
  +-----------------------------+
  |                           6 |
  +-----------------------------+
  1 row in set (0.00 sec)

  # 7. trim():去掉字符串前后指定的字符,默认去掉空格
  mysql> select trim('    a s a  ');
  +---------------------+
  | trim('    a s a  ') |
  +---------------------+
  | a s a               |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select trim('@' from '@@@@@@ass@@dadkj@@@');
  +--------------------------------------+
  | trim('@' from '@@@@@@ass@@dadkj@@@') |
  +--------------------------------------+
  | ass@@dadkj                           |
  +--------------------------------------+
  1 row in set (0.00 sec)
  
  # 8. ltrim()/rtrim():删除字符串左/右边的空格
  mysql> select ltrim(' sdsd '),length(ltrim(' sdsd '));
  +-----------------+-------------------------+
  | ltrim(' sdsd ') | length(ltrim(' sdsd ')) |
  +-----------------+-------------------------+
  | sdsd            |                       5 |
  +-----------------+-------------------------+
  1 row in set (0.00 sec)

  mysql> select rtrim(' sdsd '),length(rtrim(' sdsd '));
  +-----------------+-------------------------+
  | rtrim(' sdsd ') | length(rtrim(' sdsd ')) |
  +-----------------+-------------------------+
  |  sdsd           |                       5 |
  +-----------------+-------------------------+
  1 row in set (0.00 sec)

  # 9. lpad()/rpad():左填充/右填充
  mysql> select lpad('段誉',8,'#');
  +----------------------+
  | lpad('段誉',8,'#')   |
  +----------------------+
  | ######段誉           |
  +----------------------+
  1 row in set (0.00 sec)
  
  mysql> select rpad('段誉',8,'#');
  +----------------------+
  | rpad('段誉',8,'#')   |
  +----------------------+
  | 段誉######           |
  +----------------------+
  1 row in set (0.00 sec)

  # 10. (upper()/ucase())/(lower()/lcase()):将字符串转为大/小写
  mysql> select upper('abcd');
  +---------------+
  | upper('abcd') |
  +---------------+
  | ABCD          |
  +---------------+
  1 row in set (0.00 sec)

  mysql> select lower('ABcd');
  +---------------+
  | lower('ABcd') |
  +---------------+
  | abcd          |
  +---------------+
  1 row in set (0.00 sec)
  
  mysql> select ucase('abcd');
  +---------------+
  | ucase('abcd') |
  +---------------+
  | ABCD          |
  +---------------+
  1 row in set (0.00 sec)

  mysql> select lcase('ABCD');
  +---------------+
  | lcase('ABCD') |
  +---------------+
  | abcd          |
  +---------------+
  1 row in set (0.00 sec)

  # 11. strcmp():比较两个字符串的大小
  mysql> select strcmp('abcd','aaaa');
  +-----------------------+
  | strcmp('abcd','aaaa') |
  +-----------------------+
  |                     1 |
  +-----------------------+
  1 row in set (0.00 sec)

  mysql> select strcmp('abcd','acd');
  +----------------------+
  | strcmp('abcd','acd') |
  +----------------------+
  |                   -1 |
  +----------------------+
  1 row in set (0.00 sec)

  mysql> select strcmp('abcd','abcd');
  +-----------------------+
  | strcmp('abcd','abcd') |
  +-----------------------+
  |                     0 |
  +-----------------------+

  # 12. left(string,n)/right(string,n):返回从最左/右边开始的n个字符
  mysql> select left('abcdefg',2);
  +-------------------+
  | left('abcdefg',2) |
  +-------------------+
  | ab                |
  +-------------------+
  1 row in set (0.00 sec)

  mysql> select right('abcdefg',2);
  +--------------------+
  | right('abcdefg',2) |
  +--------------------+
  | fg                 |
  +--------------------+
  1 row in set (0.00 sec)

  # 13. repeat(string,n):返回重复n次的string字符串
  mysql> select repeat('ab',4);
  +----------------+
  | repeat('ab',4) |
  +----------------+
  | abababab       |
  +----------------+

  # 14. space(n):返回由n个空格组成的字符串
  mysql> select space(5),length(space(5));
  +----------+------------------+
  | space(5) | length(space(5)) |
  +----------+------------------+
  |          |                5 |
  +----------+------------------+
  1 row in set (0.00 sec)

  # 15. replace(string,s1,s2):返回一个用s2替换string中的s1的字符串
  mysql> select replace('jalscsjvbsdjvsd','s','D');
  +------------------------------------+
  | replace('jalscsjvbsdjvsd','s','D') |
  +------------------------------------+
  | jalDcDjvbDdjvDd                    |
  +------------------------------------+
  1 row in set (0.00 sec)

  # 16. locate(str,str1):返回字符串str在str1中第一次出现的位置索引
  mysql> select locate('d','ascddev');
  +-----------------------+
  | locate('d','ascddev') |
  +-----------------------+
  |                     4 |
  +-----------------------+
  1 row in set (0.00 sec)

  # 17. position(str in str1):返回字符串str在str1中第一次出现的位置索引
  mysql> select position('d' in 'asdsajhk');
  +-----------------------------+
  | position('d' in 'asdsajhk') |
  +-----------------------------+
  |                           3 |
  +-----------------------------+
  1 row in set (0.00 sec)

  # 18. reverse(str):反转字符串
  mysql> select reverse('abcdefg');
  +--------------------+
  | reverse('abcdefg') |
  +--------------------+
  | gfedcba            |
  +--------------------+
  1 row in set (0.00 sec)

  # 19. elt(n,str1,str2,str3,...):返回第n个字符串
  mysql> select elt(2,'a','b','c','d');
  +------------------------+
  | elt(2,'a','b','c','d') |
  +------------------------+
  | b                      |
  +------------------------+
  1 row in set (0.00 sec)

  mysql> select elt(0,'a','b','c','d');
  +------------------------+
  | elt(0,'a','b','c','d') |
  +------------------------+
  | NULL                   |
  +------------------------+
  1 row in set (0.00 sec)

  mysql> select elt(8,'a','b','c','d');
  +------------------------+
  | elt(8,'a','b','c','d') |
  +------------------------+
  | NULL                   |
  +------------------------+
  1 row in set (0.00 sec)

  三、数学函数
  # 1. abs(n):返回n的绝对值
  mysql> select abs(-3);
  +---------+
  | abs(-3) |
  +---------+
  |       3 |
  +---------+
  1 row in set (0.00 sec)

  mysql> select abs(3);
  +--------+
  | abs(3) |
  +--------+
  |      3 |
  +--------+
  1 row in set (0.00 sec)

  mysql> select abs(0);
  +--------+
  | abs(0) |
  +--------+
  |      0 |
  +--------+
  1 row in set (0.00 sec)

  # 2. PI():返回圆周率,默认返回6位小数
  mysql> select pi();
  +----------+
  | pi()     |
  +----------+
  | 3.141593 |
  +----------+
  1 row in set (0.00 sec)

  # 3. sqrt(n):返回非负数的二次方根,n为负数是返回null
  mysql> select sqrt(16.9);
  +-------------------+
  | sqrt(16.9)        |
  +-------------------+
  | 4.110960958218893 |
  +-------------------+
  1 row in set (0.00 sec)

  mysql> select sqrt(-16);
  +-----------+
  | sqrt(-16) |
  +-----------+
  |      NULL |
  +-----------+
  1 row in set (0.00 sec)

  # 4. mod(x,y):返回x被y除后的余数
  mysql> select mod(7,5);
  +----------+
  | mod(7,5) |
  +----------+
  |        2 |
  +----------+
  1 row in set (0.00 sec)

  # 5. ceil(n)/ceiling(n):返回不小于n的最小整数(向上取整)
  mysql> select ceil(0.2);
  +-----------+
  | ceil(0.2) |
  +-----------+
  |         1 |
  +-----------+
  1 row in set (0.00 sec)

  mysql> select ceiling(0.2);
  +--------------+
  | ceiling(0.2) |
  +--------------+
  |            1 |
  +--------------+
  1 row in set (0.00 sec)

  mysql> select ceiling(-0.2);
  +---------------+
  | ceiling(-0.2) |
  +---------------+
  |             0 |
  +---------------+
  1 row in set (0.00 sec)

  mysql> select ceil(-0.2);
  +------------+
  | ceil(-0.2) |
  +------------+
  |          0 |
  +------------+
  1 row in set (0.00 sec)

  # 6. floor(n):返回不大于n的最大整数(向下取整)
  mysql> select floor(1.0032);
  +---------------+
  | floor(1.0032) |
  +---------------+
  |             1 |
  +---------------+
  1 row in set (0.00 sec)

  # 7. round(n[,x]):返回n的四舍五入值,x为保留的小数点位数,不传x时保留四舍五入的整数
  mysql> select round(3.456,1);
  +----------------+
  | round(3.456,1) |
  +----------------+
  |            3.5 |
  +----------------+
  1 row in set (0.00 sec)

  mysql> select round(3.456);
  +--------------+
  | round(3.456) |
  +--------------+
  |            3 |
  +--------------+
  1 row in set (0.00 sec)

  # 8. sign(n):返回n的正负号,-1表示负数,0表示0,1表示正数
  mysql> select sign(-3);
  +----------+
  | sign(-3) |
  +----------+
  |       -1 |
  +----------+
  1 row in set (0.05 sec)

  mysql> select sign(0);
  +---------+
  | sign(0) |
  +---------+
  |       0 |
  +---------+
  1 row in set (0.00 sec)

  mysql> select sign(3);
  +---------+
  | sign(3) |
  +---------+
  |       1 |
  +---------+
  1 row in set (0.00 sec)

  # 10. pow(n,x)/power(n,x):返回n的x次方
  mysql> select pow(4,2);
  +----------+
  | pow(4,2) |
  +----------+
  |       16 |
  +----------+
  1 row in set (0.00 sec)

  mysql> select power(4,2);
  +------------+
  | power(4,2) |
  +------------+
  |         16 |
  +------------+
  1 row in set (0.00 sec)

  # 11. exp(n):返回e的n乘方值
  mysql> select exp(2);
  +------------------+
  | exp(2)           |
  +------------------+
  | 7.38905609893065 |
  +------------------+
  1 row in set (0.00 sec)

  mysql> select exp(1);
  +-------------------+
  | exp(1)            |
  +-------------------+
  | 2.718281828459045 |
  +-------------------+
  1 row in set (0.00 sec)

  # 12. log(n):返回n的自然对数,n相对于基数e的对数
  mysql> select log(20);
  +-------------------+
  | log(20)           |
  +-------------------+
  | 2.995732273553991 |
  +-------------------+
  1 row in set (0.00 sec)

  # 13. radians(n):返回由n角度转化为弧度的值
  mysql> select radians(30);
  +--------------------+
  | radians(30)        |
  +--------------------+
  | 0.5235987755982988 |
  +--------------------+
  1 row in set (0.00 sec)

  # 14. degrees(n):返回由n弧度转化为角度的值
  mysql> select degrees(0.6);
  +-------------------+
  | degrees(0.6)      |
  +-------------------+
  | 34.37746770784939 |
  +-------------------+
  1 row in set (0.00 sec)

  # 15. sin(n)/asin(n):sin(n)返回n的正弦值,n为弧度值;asin(n)返回n的反正弦值,n为正弦
  mysql> select sin(0.5);
  +-------------------+
  | sin(0.5)          |
  +-------------------+
  | 0.479425538604203 |
  +-------------------+
  1 row in set (0.00 sec)

  mysql> select asin(0.5);
  +--------------------+
  | asin(0.5)          |
  +--------------------+
  | 0.5235987755982989 |
  +--------------------+
  1 row in set (0.00 sec)

  # 16. cos(n)/acos(n):cos(n)返回n的余弦值,n为弧度值;acos(n)返回n的反余弦值,n为余弦
  mysql> select cos(0.1);
  +--------------------+
  | cos(0.1)           |
  +--------------------+
  | 0.9950041652780258 |
  +--------------------+
  1 row in set (0.00 sec)

  mysql> select acos(0.1);
  +--------------------+
  | acos(0.1)          |
  +--------------------+
  | 1.4706289056333368 |
  +--------------------+
  1 row in set (0.00 sec)

  # 17. tan(n)/atan(n):返回n的正切值,n为弧度值;atan(n)返回n的反正切值,n为正切
  mysql> select tan(0.5);
  +--------------------+
  | tan(0.5)           |
  +--------------------+
  | 0.5463024898437905 |
  +--------------------+
  1 row in set (0.00 sec)

  mysql> select atan(0.5);
  +--------------------+
  | atan(0.5)          |
  +--------------------+
  | 0.4636476090008061 |
  +--------------------+
  1 row in set (0.00 sec)

  # 18. cot(n):返回弧度n的余切
  mysql> select cot(0.5);
  +-------------------+
  | cot(0.5)          |
  +-------------------+
  | 1.830487721712452 |
  +-------------------+
  1 row in set (0.01 sec)

  # 19. rand():返回0~1之间的随机数
  mysql> select rand();
  +---------------------+
  | rand()              |
  +---------------------+
  | 0.18810265342528248 |
  +---------------------+
  1 row in set (0.00 sec)


  四、日期和时间函数
  # 1. curdate()/current_date():按照'YYYY-MM-DD'或者'YYYYMMDD'格式的日期返回,具体格式看语境是字符串还是数字
  mysql> select curdate();
  +------------+
  | curdate()  |
  +------------+
  | 2020-11-17 |
  +------------+
  1 row in set (0.00 sec)

  mysql> select current_date();
  +----------------+
  | current_date() |
  +----------------+
  | 2020-11-17     |
  +----------------+
  1 row in set (0.00 sec)

  mysql> select current_date()+1;
  +------------------+
  | current_date()+1 |
  +------------------+
  |         20201118 |
  +------------------+
  1 row in set (0.00 sec)

  # 2. now()/localtime()/sysdate()/current_timestamp():以'YYYY-MM-DD HH:MM:SS'或'YYYYMMDDHHMMSS'格式返回当前时间,具体看语境是字符串还是数字
  mysql> select now();
  +---------------------+
  | now()               |
  +---------------------+
  | 2020-11-17 10:28:05 |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select localtime();
  +---------------------+
  | localtime()         |
  +---------------------+
  | 2020-11-17 10:28:13 |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select sysdate();
  +---------------------+
  | sysdate()           |
  +---------------------+
  | 2020-11-17 10:28:22 |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select current_timestamp();
  +---------------------+
  | current_timestamp() |
  +---------------------+
  | 2020-11-17 10:28:38 |
  +---------------------+
  1 row in set (0.00 sec)

  mysql> select current_timestamp()+1;
  +-----------------------+
  | current_timestamp()+1 |
  +-----------------------+
  |        20201117102908 |
  +-----------------------+
  1 row in set (0.00 sec)

  # 3. unix_timestamp([date/datetime]):返回给定时间的时间戳
  mysql> select unix_timestamp();
  +------------------+
  | unix_timestamp() |
  +------------------+
  |       1605580405 |
  +------------------+
  1 row in set (0.00 sec)

  mysql> select unix_timestamp('2020-11-17 10:33:30');
  +---------------------------------------+
  | unix_timestamp('2020-11-17 10:33:30') |
  +---------------------------------------+
  |                            1605580410 |
  +---------------------------------------+
  1 row in set (0.00 sec)

  mysql> select unix_timestamp('2020-11-17');
  +------------------------------+
  | unix_timestamp('2020-11-17') |
  +------------------------------+
  |                   1605542400 |
  +------------------------------+
  1 row in set (0.00 sec)

  # 4. from_unixtime(timestamp):unix_timestamp()的反函数,将时间戳转换为'YYYY-MM-DD HH:MM:SS.毫秒'
  mysql> select from_unixtime('1605542400');
  +-----------------------------+
  | from_unixtime('1605542400') |
  +-----------------------------+
  | 2020-11-17 00:00:00.000000  |
  +-----------------------------+
  1 row in set (0.00 sec)
  
  # 5. utc_date():返回当前utc(世界标准时间)日期值,格式'YYYY-MM-DD'或'YYYYMMDD',具体格式看语境
  mysql> select utc_date();
  +------------+
  | utc_date() |
  +------------+
  | 2020-11-17 |
  +------------+
  1 row in set (0.00 sec)

  mysql> select utc_date()+0;
  +--------------+
  | utc_date()+0 |
  +--------------+
  |     20201117 |
  +--------------+
  1 row in set (0.00 sec)

  # 6. utc_time():返回当前utc(世界标准时间)时间值,格式'HH:MM:SS'或'HHMMSS',具体格式看语境
  mysql> select utc_time();
  +------------+
  | utc_time() |
  +------------+
  | 02:51:01   |
  +------------+
  1 row in set (0.00 sec)

  mysql> select utc_time()+0;
  +--------------+
  | utc_time()+0 |
  +--------------+
  |        25103 |
  +--------------+
  1 row in set (0.00 sec)

  # 7. month(date/datetime):返回指定日期的月份
  mysql> select month(now());
  +--------------+
  | month(now()) |
  +--------------+
  |           11 |
  +--------------+
  1 row in set (0.00 sec)

  mysql> select month(curdate());
  +------------------+
  | month(curdate()) |
  +------------------+
  |               11 |
  +------------------+
  1 row in set (0.00 sec)

  # 8. monthname(date/datetime):返回指定日期的月份英文名称
  mysql> select monthname(now());
  +------------------+
  | monthname(now()) |
  +------------------+
  | November         |
  +------------------+
  1 row in set (0.00 sec)

  mysql> select monthname(curdate());
  +----------------------+
  | monthname(curdate()) |
  +----------------------+
  | November             |
  +----------------------+
  1 row in set (0.00 sec)

  # 9. dayname(date/datetime):返回周几的英文名
  mysql> select dayname(now());
  +----------------+
  | dayname(now()) |
  +----------------+
  | Tuesday        |
  +----------------+
  1 row in set (0.00 sec)

  mysql> select dayname(utc_date());
  +---------------------+
  | dayname(utc_date()) |
  +---------------------+
  | Tuesday             |
  +---------------------+
  1 row in set (0.00 sec)

  # 10. dayofweek(date/datetime):返回给定的日期是一周中的第几天(周日是第一天,值为1)
  mysql> select dayofweek(now());
  +------------------+
  | dayofweek(now()) |
  +------------------+
  |                3 |
  +------------------+
  1 row in set (0.00 sec)

  mysql> select dayofweek(utc_date());
  +-----------------------+
  | dayofweek(utc_date()) |
  +-----------------------+
  |                     3 |
  +-----------------------+
  1 row in set (0.00 sec)

  # 11. weekday(date/datetime):返回给定的日期是一周中的第几天(周日是第一天,值为0)
  mysql> select weekday(utc_date());
  +---------------------+
  | weekday(utc_date()) |
  +---------------------+
  |                   1 |
  +---------------------+
  1 row in set (0.00 sec)

  # 12. week(date[,mode]):返回一年中的第几周
  mysql> select week(now()),week(now(),3);
  +-------------+---------------+
  | week(now()) | week(now(),3) |
  +-------------+---------------+
  |          46 |            47 |
  +-------------+---------------+
  1 row in set (0.01 sec)


  # 13. weekofyear(date):返回日期的日历周(1-53)和week(date,3)相同
  mysql> select weekofyear(now());
  +-------------------+
  | weekofyear(now()) |
  +-------------------+
  |                47 |
  +-------------------+
  1 row in set (0.00 sec)

  # 14. dayofyear(date)/dayofmonth(date):返回一年/一个月中的第几天
  mysql> select dayofyear(now()),dayofmonth(now());
  +------------------+-------------------+
  | dayofyear(now()) | dayofmonth(now()) |
  +------------------+-------------------+
  |              322 |                17 |
  +------------------+-------------------+
  1 row in set (0.00 sec)
  

  # 15. year(date):返回指定日期的年份;quarter(date):返回一年中的第几季度(1~4);minute(time):返回给定时间的分钟数(0~59);second(time):返回给定时间的秒数(0~59)
  mysql> select year(now()),quarter(now()),minute(utc_time()),second(utc_time());
  +-------------+----------------+--------------------+--------------------+
  | year(now()) | quarter(now()) | minute(utc_time()) | second(utc_time()) |
  +-------------+----------------+--------------------+--------------------+
  |        2020 |              4 |                 25 |                 21 |
  +-------------+----------------+--------------------+--------------------+
  1 row in set (0.00 sec)

  # 16. extract(type from date):从日期中按照type提取内容(type:YEAR、YEAR_MONTH、DAY_HOUR、DAY_MICROSECOND、DAY_MINUTE、DAY_SECOND)
  mysql> select extract(year from now()),extract(year_month from now()),extract(day_hour from now());
  +--------------------------+--------------------------------+------------------------------+
  | extract(year from now()) | extract(year_month from now()) | extract(day_hour from now()) |
  +--------------------------+--------------------------------+------------------------------+
  |                     2020 |                         202011 |                           11 |
  +--------------------------+--------------------------------+------------------------------+
  1 row in set (0.00 sec)


  # 17. datediff(date1,date2):返回两个日期之间相差的天数
  mysql> select datediff('2020-11-17','2019-11-17');
  +-------------------------------------+
  | datediff('2020-11-17','2019-11-17') |
  +-------------------------------------+
  |                                 366 |
  +-------------------------------------+
  1 row in set (0.00 sec)

  # 18. time_to_sec(time):将时间转换成秒数
  mysql> select time_to_sec(curtime());
  +------------------------+
  | time_to_sec(curtime()) |
  +------------------------+
  |                  42101 |
  +------------------------+
  1 row in set (0.00 sec)

  # 19. sec_to_time(second):将秒数转换成时间格式
  mysql> select sec_to_time(42101);
  +--------------------+
  | sec_to_time(42101) |
  +--------------------+
  | 11:41:41           |
  +--------------------+
  1 row in set (0.00 sec)

  五、系统信息函数
  # 1. version():查看MySQL版本号
  # 2. user()/current_user()/system_user()/session_user():查看当前被MySQL服务器验证的用户名和主机的组合,一般这几个函数的返回值是相同的
  # 3. connection_id():查看当前用户的连接数
  # 4. charset(str):查看字符串str使用的字符集
  六、加密函数
  # 1. password(str):
  从原明文密码str计算并返回加密后的字符串密码,注意这个函数的加密是单向的(不可逆),因此不应将它应用在个人的应用程序中而应该只在MySQL服务器的鉴定系统中使用
  MySQL5.7.9以后废弃
  # 2. md5('str'):
  为字符串算出一个MD5 128比特校验和,改值以32位十六进制数字的二进制字符串形式返回
  # 3. encode(str, pswd_str):结果是一个二进制数,必须使用blob类型的字段来保存它;
  # 4. decode(crypt_str,pswd_str):使用pswd_str作为密码,解密加密字符串crypt_str,crypt_str是由ENCODE函数返回的字符串
  七、其他函数
  # 1. format(x,n):格式化数字,并以四舍五入的方式保留小数点n位,结果是字符串
  mysql> select format(2323.34,1);
  +-------------------+
  | format(2323.34,1) |
  +-------------------+
  | 2,323.3           |
  +-------------------+
  1 row in set (0.00 sec)

  # 2. conv(N,from_base,to_base):不同进制数之间的转换,返回值为数值N的字符串表示,由from_base进制转换为
  mysql> select conv(4,10,2);
  +--------------+
  | conv(4,10,2) |
  +--------------+
  | 100          |
  +--------------+
  1 row in set (0.00 sec)

  # 3. hex(N):将十进制数字N转换成16进制;bin(N):将十进制数字N转换成二进制;oct(N):将十进制数字转换成8进制
  mysql> select hex(10),bin(10),oct(10);
  +---------+---------+---------+
  | hex(10) | bin(10) | oct(10) |
  +---------+---------+---------+
  | A       | 1010    | 12      |
  +---------+---------+---------+
  1 row in set (0.04 sec)


  # 4. benchmark(count,expr):
  重复执行count次表达式expr,它可以用于计算MySQL处理表达式的速度,结果值通常是0(0只是表示很快,并不是没有速度)。
  另一个作用是用它在MySQL客户端内部报告语句执行的时间
  mysql> select benchmark(3,9*3);
  +------------------+
  | benchmark(3,9*3) |
  +------------------+
  |                0 |
  +------------------+
  1 row in set (0.03 sec)
  
  # 5. convert(str,type)/cast(str as type):可用来获取一个类型的值,并产生另一个类型的值。
  type:值可以是
  1)二进制,同带binary前缀的效果 : BINARY    
  2)字符型,可带参数 : CHAR()     
  3)日期 : DATE     
  4)时间: TIME     
  5)日期时间型 : DATETIME     
  6)浮点数 : DECIMAL      
  7)整数 : SIGNED     
  8)无符号整数 : UNSIGNED 
  mysql> select cast('235ad123' as signed),cast('235ad123' as unsigned),cast('235ad123' as BINARY);
  +----------------------------+------------------------------+--------------------------------------------------------+
  | cast('235ad123' as signed) | cast('235ad123' as unsigned) | cast('235ad123' as BINARY)                             |
  +----------------------------+------------------------------+--------------------------------------------------------+
  |                        235 |                          235 | 0x3233356164313233                                     |
  +----------------------------+------------------------------+--------------------------------------------------------+
  1 row in set, 2 warnings (0.03 sec)

  mysql> select convert('235ad123',signed),convert('235ad123',unsigned),convert('235ad123',BINARY);
  +----------------------------+------------------------------+--------------------------------------------------------+
  | convert('235ad123',signed) | convert('235ad123',unsigned) | convert('235ad123',BINARY)                             |
  +----------------------------+------------------------------+--------------------------------------------------------+
  |                        235 |                          235 | 0x3233356164313233                                     |
  +----------------------------+------------------------------+--------------------------------------------------------+
  1 row in set, 2 warnings (0.00 sec)

  八、聚合函数:
  # 1. count(*):返回查询结果的总数
  mysql> select count(*) from students;
  +----------+
  | count(*) |
  +----------+
  |       42 |
  +----------+
  1 row in set (0.33 sec)

  # 2. sum(字段):返回查询字段的总和
  mysql> select sum(score) from students;
  +------------+
  | sum(score) |
  +------------+
  |       2371 |
  +------------+
  1 row in set (0.00 sec)
  
  # 3. avg(字段):返回查询字段的平均值
  mysql> select avg(score) from students;
  +------------+
  | avg(score) |
  +------------+
  |    67.7429 |
  +------------+
  1 row in set (0.02 sec)

  # 4. max(字段):返回查询字段的最大值;min(字段):返回查询字段的最小值
  mysql> select max(score),min(score) from students;
  +------------+------------+
  | max(score) | min(score) |
  +------------+------------+
  |        100 |          0 |
  +------------+------------+
  1 row in set (0.02 sec)


  更多MySQL函数请查阅:[https://www.jc2182.com/mysql/mysql-adddate.html](https://www.jc2182.com/mysql/mysql-adddate.html)
posted @ 2020-11-17 14:11  huige185  阅读(107)  评论(0编辑  收藏  举报