2

MySQL functions

Introduction to MySQL functions

  1. Mathematical function
  2. String function
  3. Time function
  4. Encryption function

Mathematical function

Note: each function needs to add : SELECT before each function.

  • Mathematical function

    • ABS () Return absolute value such as: (-100) Value: 100
    • PI () Return the compass rate of Π such as (do not write) Value: 3.1415926
    • CEIL () Round up to an integer such as: (3.14) Value: 4 (note that the third is i)
  • FLOOR() down to an integer such as: (3.14) Value: 3
  • POW(x,y) x to the y power such as (2,3) Value: 8
  • RAND() randomly returns 0-1 value such as: () Value: 0.018137501569592863
  • TRUNCATE(x,y) x retains y decimal places such as: (3.1415926,3) Value: 3.141
-- abs() 绝对值
SELECT ABS (-100);

-- pi() 返回圆 Π 规率
SELECT PI();

--  SQRT ()返回非负数x的二次方
SELECT SQRT(2);

--  POW 返回 x的 y 次乘方 需要
SELECT POW(2,10);
SELECT POWER(2,10)

-- CELL() or 
SELECT CEIL(3.14);  -- 向上取整数

-- floor()
SELECT FLOOR(3.14); -- 向下取整数

-- round() 四舍五入取整数 还可以保留小数
SELECT ROUND(3.4);
SELECT ROUND(3.5);
SELECT ROUND(3.7,2)


-- pow() x 的 y 次方
SELECT POW(2,3);


-- random 随机0到1 
SELECT RAND();

-- truncate() 保留小数 选择 
SELECT TRUNCATE(3.14159265758,3);
SELECT TRUNCATE(RAND()* 1000 ,3);

String function

  • String function

    • LENGTH() gets the length such as: ('abc') value: 3
    • CHAR_LENGTH length such as: ('add') value: 3
    • UPPER() All uppercase English in the string ('abcde') Value: ABCDE
    • LOWER() string in English all lowercase ()
    • TRIM() remove the space
    • REVERES() reverse
    • REPLACE(str, instead of len2
    • SUBSTRLNG(y,z) intercept y to z
-- 字符串函数  -- RIGHT

SELECT LENGTH('fdsajfadslksdafk');

SELECT CHAR_LENGTH('fdsajfadslksdafk');

-- lower upper  --全部变成大写、小写
SELECT UPPER('fdsajfadslksdafk');
SELECT LOWER('AFASDF');

-- trim()  去两端空格
SELECT TRIM( ' abc ' )
SELECT TRIM('    afdjkadsfjkll  asd;fasf     ');

-- reverse() 反转
SELECT REVERSE('abcdefg');
SELECT REVERSE(TRIM('    afdjkadsfjkll  asd;fasf     '));、


-- replace(str,len1,len2) len1 代替 len2
SELECT REPLACE('QQ群个个都是人才,说话又好听' , '人才', '鬼才');

SELECT REPLACE('路演其是班草', '阿呆呆', '曹某某');

--  截取 y 截取 z 
SELECT SUBSTRING('监x里个个都是人才,说话又好听',4,5);

Date function

  • Date function

    • SYSDATE() system date + time
    • CURDATE() system date
    • CURETIME() system time
    • WEEKDAY() return date parameter Note time: 0-6 need +1
    • DAYNAME() system tells you what day of the week is today
  • YEAR() year check
  • MONTH() month check
  • DAY() check the day
  • HOUR() check
  • MINUTE() check score
  • SECOUND()
  • WEEK() Check the week

ADDDATE (DATE, interval The, value) appended to date obtained as: (NOW (), INTERVAL, 50 YEAR)

the DATEDIFF (DATE, DATE) even worth spaced as: ABS (DATEDIFF ( '2005-8-26' , '2021-9-23'))

-- 日期函数

-- 系统当前日期 sysdate()
SELECT SYSDATE() 系统当前日期; -- 要 时分秒 
-- (日期和时间)
SELECT CURDATE() 系统当前日期; -- 当前的日期 
-- (日期)
SELECT CURTIME() 系统当前时间 ;
-- (时间)

--  dayofweek() 今天时本周week -月month - 年year
SELECT DAYOFYEAR(SYSDATE()) 今天是这一年的第几天;
SELECT DAYOFMONTH(SYSDATE()) 今天是这一月的第几天; 
SELECT DAYOFWEEK('2021-9-19')  今天是这一周的第几天; -- 1-7

-- weekday 
SELECT WEEKDAY(SYSDATE()) + 1 今天是星期几; -- 0-6

-- dayname 星期几 
SELECT DAYNAME('2001-9-18') 

-- 年月日时分秒 year month day hour minute second
SELECT YEAR(SYSDATE()) 年;
SELECT MONTH(SYSDATE()) 月;
SELECT DAY(SYSDATE()) 日;

SELECT HOUR(SYSDATE()) 时;
SELECT MINUTE(SYSDATE()) 分;
SELECT SECOND(SYSDATE()) 秒; 
-- 周 
SELECT WEEK(SYSDATE()) 周; 


-- adddate(date,interval expr type)  添加时间后的日期
-- 假设你还有50年寿命,50年后这个时间是多少
SELECT ADDDATE(NOW(),INTERVAL 50 YEAR);
SELECT ADDDATE(NOW(), INTERVAL 50 SECOND);

-- datediff(date1, date2) 两个时间的间隔  
SELECT ABS(DATEDIFF('2005-8-26','2021-9-23')); -- 1984 - 3 - 24


-- 假设路演其出生时间2005年7月15 请问他到选择活了多少分钟
-- 假设他还有80年的寿命 80年后是多久

SELECT  ABS(DATEDIFF('2005-7-15',SYSDATE()) ) * 1444  ;

SELECT  ADDDATE(NOW(), INTERVAL 80 YEAR);

Encryption function

  • PASSWORD (str) cannot be reversed after encryption
  • MD5 (str) can be reversed after encryption Note: previously not allowed
  • CHARSET () View mysel version

-- 加密函数

SELECT PASSWORD('123456') 加密后不可以逆转;
SELECT PASSWORD('666666') 加密后不可以逆转;

-- MD5
SELECT PASSWORD('123456') 加密后不可以逆转 MD5('123456') 加密后可以逆转

-- 版本查看
SELECT VERSION();
SELECT CHARSET('123456');


-- md5 加密
-- 雪花推特算法 




嘻嘻硕
27 声望12 粉丝

想当一只天然呆的鸭qwq