MySQL 之 - MySQL函数
来源:SegmentFault
2023-01-10 13:30:25
0浏览
收藏
你在学习数据库相关的知识吗?本文《MySQL 之 - MySQL函数》,主要介绍的内容就涉及到MySQL,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
MySQL提供了众多功能强大、方便易用的函数。使用这些函数,可以极大的提高用户对数据库的管理效率。MySQL中的函数包括:数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数等其他函数。下面介绍MySQL中的这些函数的功能和用法。
一. MySQL函数简介
函数表示对输入参数值返回一个具体特定关系的值,MySQL提供了大量丰富的函数,在进行数据库的管理以及数据的查询操作时将会经常用到各种函数。通过对数据的处理,数据库功能变得更加强大,更加灵活的满足不同用户的需求。各类函数从功能方面主要分为以下几类:数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数等其他函数。
1.1 数学函数
数学函数主要用来处理数值数据,主要的数学函数有:绝对值函数、三角函数(包括正弦函数、余弦函数,正切函数、余切函数等)、对数函数、随机数函数等。再有错误产生时,数学函数会返回空值NULL。下面介绍各种数学函数的功能和用法。
ABS(x)返回X的绝对值
求2,-2.3,-34的绝对值,SQL语句:
SELECT ABS(2),ABS(-2.2),ABS(-34);

求圆周率的值:(结果保留了7位有效数字)
SELECT PI();

1.2 平方根函数SQRT(x)和求余函数MOD(x,y)
SQRT(x)返回非负数x的二次方根
求9,40,-49的二次方根,SQL如下:
SELECT SQRT(9),SQRT(40),SQRT(-49);

MOD(x,y)返回x被y除后的余数,MOD()对于带有小数部分的数值也起作用,他返回除法运算后的精确余数。
对MOD(31,8),MOD(234,10),MOD(45.5,6)进行求余预算,SQL如下:
SELECT MOD(31,8),MOD(234,10),MOD(45.5,6);

1.3 获取整数的函数CEIL(x),CEILING(x)和FLOOR(x)
CEIL(x)和CEILING(x)返回不小于x的最小整数值,返回值转化为一个BIGINT。
使用CEILING函数返回最小整数值,SQL如下:
SELECT CEIL(-3.35),CEILING(3.35);

FLOOR(x)返回不大于x的最大正整数,转化为一个BIGINT。
使用FLOOR(x)返回不大于x的最大整数,SQL如下:
SELECT FLOOR(-3.35),FLOOR(3.35);

1.4 获取随机数的函数RAND()和RAND(x)
RAND(x)返回一个随机浮点值v,范围在0-1之间(即0
使用RAND()函数产生随机数,SQL如下:
SELECT RAND(),RAND(),RAND();

可以看到,不带参数的RAND()每次产生的随机数是不同的。
使用RAND(x)函数产生随机数,SQL如下:
SELECT
RAND(10),RAND(10),RAND(11),RAND(11);

可以看到,当RAND(x)的参数相同时,将产生相同的随机数,不同的x产生的随机数不同。
1.5 四舍五入函数ROUND(x)、ROUND(x,y)、TRUNCATE(x,y)
ROUND(x)返回最接近于参数x的整数,对x值进行四舍五入。
使用ROUND(X)函数对操作数进行四舍五入,输入语句如下:
SELECT ROUND(-1.14),ROUND(-1.67),ROUND(1.14),ROUND(1.66);

可以看到,四舍五入处理之后,只保留了各个值得整数部分 ROUND(X,Y)返回最接近于X的数,其值保留到小数点后Y位,若Y为负值,则将保留X值到小数点左边Y位。
SELECT ROUND(1.38,1),ROUND(1.38,0),ROUND(232.38,-1),ROUND(232.38,-2);

ROUND(1.38,1)保留小数点后面1位,四舍五入后的结果为1.4; ROUND(1.38,0)保留小数点后0位,即返回四舍五入之后的整数值; ROUND(232.38,-1)和ROUND(232.38,-2)分别保留小数点后1位和2位。 注释:Y为负值时,保留的小数点左边的相应位数直接保存为0,不进行四舍五入。
TRUNCATE(X,Y)
TRUNCATE(X,Y)返回被舍去至小数点后y位的数字x,如y为0,则结果不带有小数点或者不带有小数部分。若y设为负数,则截去(归零)x小数点左起第y位开始后面所有低位的值。
SELECT TRUNCATE(1.31,1),TRUNCATE(1.99,1),TRUNCATE(1.99,0),TRUNCATE(19.99,-1)

round(x,y)会进行四舍五入,TRUNCATE(x,y)不会进行四舍五入。
1.6符号函数SIGN(x)
SIGN(x)返回参数的符号,x的值为负,0或正时返回的结果依次是-1,0,1。
SELECT SIGN(-21),SIGN(0),SIGN(21);

1.7幂运算函数POW(x,y),POWER(x,y),EXP(x)
POW(x,y)或者POWER(x,y)函数依次返回x的y次方结果值。
SELECT POW(2,2),POWER(2,2),POW(2,-2),POWER(2,-2);

二.字符串函数
2.1 计算字符串字符数的函数,和字符串长度的函数
CHAR_LENGTH(str)返回的是字符串str所包含的字符个数。一个多字节字符算一个单字符。
SELECT CHAR_LENGTH('date'),CHAR_LENGTH('egg');

2.2 合并字符串函数CONCAT(s1,s2,...),CONCAT_WS(x,s1,s2,...)
CONCAT(s1,s2,...)返回结果为连接参数产生的字符串,或许有一个或多个参数。如果有任何一个参数为NULL,则返回NULL值。如果所有参数均为非二进制字符串,则结果为非二进制字符串。如果自变量中含有任何一个二进制字符串,则结果为一个二进制字符串。
CONCAT(s1,s2,...),
SELECT CONCAT('mysql','5.6'),CONCAT('MY',NULL,'SQL');

CONCAT('MYSQL',NULL,'SQL')中有一个参数为NULL,因此返回结果为NULL。
CONCAT_WS(x,s1,s2,...)
SELECT CONCAT_WS('-','1st','2nd','3rd'),CONCAT_WS('*','1st',NULL,'3rd');

`CONCAT('-','1st','2nd','3rd')使用分隔符'-'将3个字符串连接成一个字符串。CONCAT_WS('*','1st',NULL,'3rd')使用分隔符‘*’将字符串连接成一个字符串,同时忽略NULL值。`
2.3替换字符串的函数INSERT(s1,x,len,s2)
INSERT(s1,x,len,s2)返回字符串s1,其字符串起始于x位置和被字符串s2取代的len字符。如果x超过字符串长度,则返回原始字符串。假如len的长度大于其他字符串的长度,则从位置x开始替换。若任何一个参数为NULL,则返回值为NULL。
SELECT INSERT('Quest',2,3,'What') as col1, INSERT('Quest',-1,4,'What') col2, INSERT('Quest',3,100,'What') col3;

第一个函数INSERT('Quest',2,3,'What')将'Quest'第2个字符开始长度为4的字符串替换为'What',结果为'QWhat';第二个函数INSERT('Quest',-1,4,'What')中起始位置为-1超出了字符串长度,直接返回原始字符;第三个函数INSERT('Quest',3,100,'What'),替换长度超出了原始字符串长度,则从第3个字符开始截取后面所有的字符,并替换为指定字符What,结果为'QuWhat'。
2.4 字母大小写转换LOWER(str),LCASE(str)
LOWER(str)或者LCASE(str)可以将字符串str中的字母字符全部转换为小写字母。
SELECT LOWER('HELLO'),LCASE('HELLOWORLD'); SELECT UPPPER('hello'),UCASE('HElloWorld');


2.5 获取指定长度的字符串的函数LEFT(s,n)和RIGHT(s,n)
LEFT(s,n)返回字符串s,开始的最左边n个字符。
SELECT LEFT('helloworld', 3); SELECT RIGHT('helloworld', 3);


2.6 删除空格函数 LTRIM(S),RTRIM(S),TRIM(S)
2.7 删除指定字符串的函数TRIM(s1 FROM s)
SELECT TRIM('XY' FROM 'XYXBOXYXXYXY');

删除字符串'XYXBOXYXXYXY'两端的重复字符串'XY',而中间'XY'并不删除,结果为'XBOXYX'
2.8 重复生成字符串的函数REPEAT(S,N)
REPEAT(s,n)返回一个由重复的字符串s组成的字符串,字符串s的数目等于n,若n
SELECT REPEAT('Mysql', 3);

2.9 空格函数SPACE(n),替换函数replace(s,s1,s2)
SELECT REPLACE('xxx,baidu.com','x','w')

2.10 比较字符串大小(长度)的函数STRCMP(s1,s2)
STRCMP(s1,s2)若所有的字符串均相同,则返回0。若根据当前分类次序,第一个参数长度小于第二个,则返回-1,其他情况返回1. SELECT STRCMP('test','test2'),STRCMP('test1','test'),STRCMP('test','test')

2.11 获取子串的函数SUBSTRING(s,n,len)和MID(s,n,len),二者作用相同
SELECT SUBSTRING('breakfast',5), SUBSTRING('breakfast',5,3), SUBSTRING('breakfast',-3), SUBSTRING('breakfast',-5,3);

2.12 匹配子串开始位置的函数LOCATE(str1,str)、POSITION(str1 IN str)、INSTR(str,str1)三个函数作用相同。
SELECT LOCATE('ball','football'), POSITION('ball' IN 'football'), INSTR('football','ball');

2.13 字符串逆序的函数REVERSE(s)
SELECT REVERSE('abc');

2.14 返回指定位置的字符串函数ELT(N,str1,str2,str3)
SELECT ELT(3,'1st','2nd','3rd'), ELT(3,'1st','2nd');

2.15 返回指定字符串位置的函数FIELD(s,s1,s2,...)
SELECT FIELD('aa','bb','cc','aa','dd');

2.16 返回子串位置的函数FIND_IN_SET(s1,s2)
SELECT FIND_IN_SET('Hi','hihi,Hi,Hey,bas');

三.日期和时间函数
3.0 CAST函数
Cast(字段名 as 转换的类型 ),其中类型可以为: CHAR\[(N)\] 字符型 DATE 日期型 DATETIME 日期和时间型 DECIMAL float型 SIGNED int TIME 时间型 ``` SELECT CAST('2012-02-21 12:21:30' as DATE) SELECT CAST('2012-02-21 12:21:30' as DATETIME); SELECT CAST('2012-02-21 12:21:30' as TIME); ```   
3.1 获取当前日期的函数和获取当前时间的函数CURDATE()、CURRENT_DATE()
CURDATE()和CURRENT_DATE()函数作用相同,将当前日期按照YYYY-MM-DD或YYYYMMDD返回。 SELECT CURDATE(),CURRENT_DATE(),CURDATE()+0;

SELECT CURTIME(),CURRENT_TIME(),CURTIME()+0;

3.2 获取当前日期和时间的函数CURRENT_TIMESTAMP()、LOCALTIME()、NOW()、SYSDATE()
SELECT
CURRENT_TIMESTAMP(),LOCALTIME(),NOW(),SYSDATE();

3.3 时间戳函数UNIX_TIMESTAMP('yyyy-mm-dd 00:00:00')
SELECT UNIX_TIMESTAMP(NOW()),UNIX_TIMESTAMP('2019-12-12 12:23:12');

3.4 获取月份的函数MONTH(date)和MONTHNAME(date)
SELECT MONTH(NOW()), MONTHNAME(NOW()), MONTH('2019-1-22'), MONTHNAME('2019-1-22');

3.5 获取星期的函数DAYWEEK(d),DAYOFWEEK(d),WEEKDAY(d)
SELECT DAYNAME(NOW()),DAYOFWEEK('2019-12-20') as '周索引',WEEKDAY('2019-12-20') as '日索引';

3.6 获取星期数的函数WEEK(d)和WEEKOFYEAR(d)
3.7 获取天数的函数DAYOFYEAR(d)和DAYOFMONTH(d)
3.8 获取年份,嫉妒,小时,分钟,秒的函数YEAR(d),QUARTER(d),MINUTE(time),SECOND(time)
SELECT YEAR('19-12-12') '年份', QUARTER('2019-12-12') '第几个季度', MINUTE('12:21:20') '分钟', SECOND('12:21:20') '秒';

3.9 获取日期的指定值函数EXTRACT(type FROM date)
SELECT EXTRACT(YEAR FROM '2019-12-20 09:21:12') '年', EXTRACT(YEAR_MONTH FROM '2019-12-20 09:21:12') '年月', EXTRACT(DAY_MINUTE FROM '2019-12-20 09:21:12') '日-分钟';

3.10 时间和秒钟转换的函数TIME_TO_SEC(time)
SELECT TIME_TO_SEC('23:23:00');

SEC_TO_TIME(seconds)返回被转化为小时,分钟,秒数的seconds参数值,其格式为HH:MM:SS或HHMMSS。 SELECT SEC_TO_TIME(84180), SEC_TO_TIME(84180)+0;

3.11 计算日期和时间的函数
DATE_ADD(),ADDDATE(),DATE_SUB(),SUBDATE(),ADDTIME(),SUBTIME(),DATE_DIFF() SELECT DATE_ADD('2010-12-31 23:59:59', interval 1 SECOND) '当前时间+1秒';

mysql中计算日期和时间格式
type值 | 预期的exp格式 |
---|---|
SECOND | SECONDS |
MINUTE | MINUTES |
HOUR | HOURS |
MONTH | MONTHS |
YEAR | YEARS |
QUARTER(季度) | QUARTERS |
... | ... |
四、条件判断函数
4.1 IF(expr,v1,v2)函数
今天关于《MySQL 之 - MySQL函数》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- MySQL 之 LEFT JOIN 避坑指南

- 下一篇
- Python|队列Queue
评论列表
-
- 糊涂的嚓茶
- 太细致了,已加入收藏夹了,感谢up主的这篇技术贴,我会继续支持!
- 2023-01-24 05:42:24
-
- 洁净的灯泡
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢博主分享技术贴!
- 2023-01-18 22:42:28
-
- 感动的小懒猪
- 这篇文章内容出现的刚刚好,太细致了,很好,码住,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-01-14 07:07:30
查看更多
最新文章
-
- 数据库 · MySQL | 4小时前 | 索引 数据类型 约束 主键 CREATETABLE
- MySQL建表命令详解:CREATETABLE示例及解释
- 206浏览 收藏
-
- 数据库 · MySQL | 19小时前 | 数据类型 扩展性 存储引擎 CREATETABLE 约束条件
- MySQL建表攻略:详解数据表创建方法
- 265浏览 收藏
-
- 数据库 · MySQL | 22小时前 | mysql 字符集 中文乱码 utf8mb4 utf8mb4_unicode_ci
- MySQL中文乱码解决方案与字符集修改命令大全
- 339浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 24次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 38次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 37次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 48次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 41次使用
查看更多
相关文章
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览