共计 5359 个字符,预计需要花费 14 分钟才能阅读完成。
自动写代码机器人,免费开通
丸趣 TV 小编给大家分享一下 MySQL 函数有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
MySQL 函数
常用函数
聚合函数
数据库级别的 MD5 加密
常用函数
函数作用例子 ABS(x)返回 x 的绝对值 SELECT ABS(-1) – 返回 1CEIL(x),CEILING(x)返回大于或等于 x 的最小整数 SELECT CEIL(1.5) – 返回 2FLOOR(x)返回小于或等于 x 的最大整数 SELECT FLOOR(1.5) – 返回 1RAND()返回 0 - 1 的随机数 SELECT RAND() –0.6264973735683573RAND(x)返回 0 - 1 的随机数,x 值相同时返回的随机数相同 SELECT RAND(2) – 1.5865798029924SIGN(x)返回 x 的符号,x 是负数、0、正数分别返回 -1、0 和 1SELECT SIGN(-10) – (-1)PI()返回圆周率 (3.141593)SELECT PI()– 3.141593TRUNCATE(x,y) 返回数值 x 保留到小数点后 y 位的值(与 ROUND 最大的区别是不会进行四舍五入)SELECT TRUNCATE(1.23456,3) – 1.234ROUND(x)返回离 x 最近的整数 SELECT ROUND(1.23456) – 1ROUND(x,y)保留 x 小数点后 y 位的值,但截断时要进行四舍五入 SELECT ROUND(1.23456,3) – 1.235POW(x,y).POWER(x,y)返回 x 的 y 次方 SELECT POW(2,3) – 8SQRT(x)返回 x 的平方根 SELECT SQRT(25) – 5EXP(x)返回 e 的 x 次方 SELECT EXP(3) – 20.085536923188MOD(x,y)返回 x 除以 y 以后的余数 SELECT MOD(5,2) – 1LOG(x)返回自然对数 (以 e 为底的对数)SELECT LOG(20.085536923188) – 3LOG10(x) 返回以 10 为底的对数 SELECT LOG10(100) – 2RADIANS(x)将角度转换为弧度 SELECT RADIANS(180) – 3.1415926535898DEGREES(x)将弧度转换为角度 SELECT DEGREES(3.1415926535898) – 180SIN(x)求正弦值 (参数是弧度)SELECT SIN(RADIANS(30)) – 0.5ASIN(x) 求反正弦值 (参数是弧度)
COS(x) 求余弦值 (参数是弧度)SELECT COS(RADIANS(30)) –0.5ACOS(x) 求反余弦值 (参数是弧度)
TAN(x) 求正切值 (参数是弧度)SELECT TAN(RADIANS(45)) –1ATAN(x) ATAN2(x) 求反正切值 (参数是弧度)
COT(x) 求余切值(参数是弧度)
-- 数学运算 SELECT ABS(-8) as 绝对值 -- 绝对值 SELECT CEILING(9.4) -- 向上取整 SELECT FLOOR(9.4) -- 向下取整 SELECT RAND() -- 返回一个 0-1 之间的随机数 SELECT SIGN(-10) -- 返回一个数的符号 0 返回 0 负数返回 -1 正数返回 1
相关免费学习推荐:mysql 视频教程
函数作用例子 CHAR_LENGTH(s)返回字符串 s 的字符数 SELECT CHAR_LENGTH(‘你好 123’) – 5LENGTH(s)返回字符串 s 的长度 SELECT LENGTH(‘你好 123’) – 9CONCAT(s1,s2,…)将字符串 s1,s2 等多个字符串合并为一个字符串 SELECT CONCAT(‘12’,‘34’) – 1234INSERT(s1,x,len,s2)将字符串 s2 替换 s1 的 x 位置开始长度为 len 的字符串 SELECT INSERT(‘12345’,1,3,‘abc’) – abc45UPPER(s),UCAASE(S)将字符串 s 的所有字母变成大写字母 SELECT UPPER(‘abc’) – ABCLOWER(s),LCASE(s)将字符串 s 的所有字母变成小写字母 SELECT LOWER(‘ABC’) – abcLEFT(s,n)返回字符串 s 的前 n 个字符 SELECT LEFT(‘abcde’,2) – abRIGHT(s,n)返回字符串 s 的后 n 个字符 SELECT RIGHT(‘abcde’,2) – deLPAD(s1,len,s2)字符串 s2 来填充 s1 的开始处,使字符串长度达到 lenSELECT LPAD(‘abc’,5,‘xx’) – xxabcRPAD(s1,len,s2)字符串 s2 来填充 s1 的结尾处,使字符串的长度达到 lenSELECT RPAD(‘abc’,5,‘xx’) – abcxxLTRIM(s)去掉字符串 s 开始处的空格
RTRIM(s) 去掉字符串 s 结尾处的空格
TRIM(s) 去掉字符串 s 开始和结尾处的空格
TRIM(s1 FROM s) 去掉字符串 s 中开始处和结尾处的字符串 s1SELECT TRIM(’@’FROM‘@@abc@@’) – abcREPEAT(s,n)将字符串 s 重复 n 次 SELECT REPEAT(‘ab’,3) – abababSPACE(n)返回 n 个空格
REPLACE(s,s1,s2) 将字符串 s2 替代字符串 s 中的字符串 s1SELECT REPLACE(‘abc’,‘a’,‘x’) –xbcSTRCMP(s1,s2)比较字符串 s1 和 s2
SUBSTRING(s,n,len)获取从字符串 s 中的第 n 个位置开始长度为 len 的字符串
MID(s,n,len) 同 SUBSTRING(s,n,len)
LOCATE(s1,s),POSITION(s1 IN s)从字符串 s 中获取 s1 的开始位置 SELECT LOCATE(‘b’,‘abc’) – 2INSTR(s,s1)从字符串 s 中获取 s1 的开始位置 SELECT INSTR(‘abc’,‘b’) – 2REVERSE(s)将字符串 s 的顺序反过来 SELECT REVERSE(‘abc’) – cbaELT(n,s1,s2,…)返回第 n 个字符串 SELECT ELT(2,‘a’,‘b’,‘c’) – bFIELD(s,s1,s2…)返回第一个与字符串 s 匹配的字符串位置 SELECT FIELD(‘c’,‘a’,‘b’,‘c’) – 3FIND_IN_SET(s1,s2)返回在字符串 s2 中与 s1 匹配的字符串的位置
-- 字符串函数 SELECT CHAR_LENGTH(我们的征途是星辰和大海) -- 字符串的长度 SELECT CONCAT(我 , 爱 , 猫猫) -- 拼接字符串 SELECT INSERT(我爱编程 helloworld ,1,2, 超级热爱) -- 查询,从某个位置开始替换某个长度 SELECT LOWER(MaoMao) -- 小写字母 SELECT UPPER(maomao) -- 全变大写 SELECT INSTR(maonmao , n) -- 返回第一次出现的子串的索引 SELECT REPLACE(猫猫说坚持就能成功 , 坚持 , 努力) -- 替换出现的指定字符串 SELECT SUBSTR(猫猫说坚持就能成功 ,4,3) -- 返回指定的子字符串 (源字符串,截取的位置,截取的长度)SELECT REVERSE(猫猫说坚持就能成功) -- 反转 -- 查询有田的同学,将田改成猪 SELECT REPLACE(studentname, 田 , 猪) FROM studentWHERE studentname LIKE % 田
函数作用例子 CURDATE();CURRENT_DATE()返回当前日期 SELECT CURDATE()– 2021-01-09NOW()返回当前日期和时间 SELECT NOW()– 2021-01-09 10:03:14LOCALTIME()返回当前日期和时间 SELECT LOCALTIME()– 2021-01-09 10:03:14UNIX_TIMESTAMP()以 UNIX 时间戳的形式返回当前时间 SELECT UNIX_TIMESTAMP()- 1617977084
-- 时间和日期函数(记住)SELECT CURRENT_DATE() -- 获取当前日期 SELECT CURDATE() -- 获取当前日期 SELECT NOW() -- 获取当前的时间 SELECT LOCALTIME() -- 本地时间 SELECT YEAR(NOW())SELECT MONTH(NOW())SELECT DAY(NOW())SELECT HOUR(NOW())SELECT MINUTE(NOW())SELECT SECOND(NOW())-- 系统 SELECT SYSTEM_USER()SELECT USER()SELECT VERSION()
聚合函数
函数名称描述 COUNT()计数 SUM()求和 AVG()平均值 MAX()最大值 MIN()最小值
-- ================ 聚合函数 ============-- 都能够统计 表中的数据 (想查询一个表中有多少个记录,就是用这个 count())SELECT COUNT(studentname) FROM student; -- COUNT(指定列),会忽略所有的 null 值 SELECT COUNT(borndate) FROM student; -- 结果 8 少一个 因为是 null
SELECT COUNT(*) FROM student; -- Count(*) 不会忽略所有的 null 值 本质 计算行数 SELECT COUNT(1) FROM result; -- Count(1) 不会忽略所有的 null 值 本质 计算行数 SELECT SUM(studentresult) AS 总和 FROM resultSELECT AVG(studentresult) AS 平均分 FROM resultSELECT MAX(studentresult) AS 最高分 FROM resultSELECT MIN(studentresult) AS 最低分 FROM result-- 查询不同课程的平均分,最高分,最低分 -- 核心:根据不同的课程分组 SELECT any_value(`subjectname`) AS 科目名,AVG(studentresult) AS 平均分,MAX(studentresult) AS 最高分,MIN(studentresult) AS 最低分 FROM result rINNER JOIN `subject` subON r.`subjectno` = sub.`subjectno`GROUP BY r.subjectno -- 通过什么字段来分组 -- 查询不同课程的平均分,最高分,最低分,平均分大于 80SELECT any_value(`subjectname`) AS 科目名,AVG(studentresult) AS 平均分,MAX(studentresult) AS 最高分,MIN(studentresult) AS 最低分 FROM result rINNER JOIN `subject` subON r.`subjectno` = sub.`subjectno`GROUP BY r.subjectno -- 通过什么字段来分组 HAVING 平均分 50
数据库级别的 MD5 加密
什么是 MD5
主要增强算法复杂度和不可逆性
MD5 不可逆,具体值的 md5 是一样的
MD5 破解网站的原理,背后有一个字典,MD5 加密后的值:MD5 加密前的值
-- ==================== 测试 MD5 加密 ===================CREATE TABLE `testmd5`(`id` INT(4) NOT NULL,
`name` VARCHAR(20) NOT NULL,
`pwd` VARCHAR(50) NOT NULL,
PRIMARY KEY(`id`))ENGINE=INNODB DEFAULT CHARSET=utf8-- 明文密码 INSERT INTO testmd5 VALUES(1, zhangsan , 123456),(2, lisi , 123456),(3, wangwu , 123456)-- 加密 UPDATE testmd5 SET pwd=MD5(pwd) WHERE id = 1UPDATE testmd5 SET pwd=MD5(pwd) -- 加密全部的密码 -- 插入的时候加密 INSERT INTO testmd5 VALUES(4, xiaoming ,MD5( 123456))-- 如何校验:将用户传递进来的密码,进行 md5 加密,然后比对加密后的值 SELECT * FROM testmd5 WHERE `name`= xiaoming AND pwd=MD5(123456)
以上是“MySQL 函数有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!
向 AI 问一下细节