MySQL有哪些单行函数

基本函数

| 函数 | 用法 |

| — | — |

| ABS(x) | 返回x的绝对值 |

| SIGN(X) | 返回X的符号。正数返回1,负数返回-1,0返回0 |

| PI() | 返回圆周率的值 |

| CEIL(x),CEILING(x) | 返回大于或等于某个值的最小整数 |

| FLOOR(x) | 返回小于或等于某个值的最大整数 |

| LEAST(e1,e2,e3…) | 返回列表中的最小值 |

| GREATEST(e1,e2,e3…) | 返回列表中的最大值 |

| MOD(x,y) | 返回X除以Y后的余数 |

| RAND() | 返回0~1的随机值 |

| RAND(x) | 返回0~1的随机值,其中x的值用作种子值,相同的X值会产生相同的随机数 |

| ROUND(x) | 返回一个对x的值进行四舍五入后,最接近于X的整数 |

| ROUND(x,y) | 返回一个对x的值进行四舍五入后最接近X的值,并保留到小数点后面Y位 |

| TRUNCATE(x,y) | 返回数字x截断为y位小数的结果 |

| SQRT(x) | 返回x的平方根。当X的值为负数时,返回NULL |

角度与弧度互换函数

| 函数 | 用法 |

| — | — |

| RADIANS(x) | 将角度转化为弧度,其中,参数x为角度值 |

| DEGREES(x) | 将弧度转化为角度,其中,参数x为弧度值 |

三角函数

| 函数 | 用法 |

| — | — |

| SIN(x) | 返回x的正弦值,其中,参数x为弧度值 |

| ASIN(x) | 返回x的反正弦值,即获取正弦为x的值。如果x的值不在-1到1之间,则返回NULL |

| COS(x) | 返回x的余弦值,其中,参数x为弧度值 |

| ACOS(x) | 返回x的反余弦值,即获取余弦为x的值。如果x的值不在-1到1之间,则返回NULL |

| TAN(x) | 返回x的正切值,其中,参数x为弧度值 |

| ATAN(x) | 返回x的反正切值,即返回正切值为x的值 |

| ATAN2(m,n) | 返回两个参数的反正切值 |

| COT(x) | 返回x的余切值,其中,X为弧度值 |

指数与对数

| 函数 | 用法 |

| — | — |

| POW(x,y),POWER(X,Y) | 返回x的y次方 |

| EXP(X) | 返回e的X次方,其中e是一个常数,2.718281828459045 |

| LN(X),LOG(X) | 返回以e为底的X的对数,当X <= 0 时,返回的结果为NULL |

| LOG10(X) | 返回以10为底的X的对数,当X <= 0 时,返回的结果为NULL |

| LOG2(X) | 返回以2为底的X的对数,当X <= 0 时,返回NULL |

进制间的转换

| 函数 | 用法 |

| — | — |

| BIN(x) | 返回x的二进制编码 |

| HEX(x) | 返回x的十六进制编码 |

| OCT(x) | 返回x的八进制编码 |

| CONV(x,f1,f2) | 返回f1进制数变成f2进制数 |

字符串函数


| 函数 | 用法 |

| — | — |

| ASCII(S) | 返回字符串S中的第一个字符的ASCII码值 |

| CHAR_LENGTH(s) | 返回字符串s的字符数。作用与CHARACTER_LENGTH(s)相同 |

| LENGTH(s) | 返回字符串s的字节数,和字符集有关 |

| CONCAT(s1,s2,…,sn) | 连接s1,s2,…,sn为一个字符串 |

| CONCAT_WS(x, s1,s2,…,sn) | 同CONCAT(s1,s2,…)函数,但是每个字符串之间要加上x |

| INSERT(str, idx, len, replacestr) | 将字符串str从第idx位置开始,len个字符长的子串替换为字符串replacestr |

| REPLACE(str, a, b) | 用字符串b替换字符串str中所有出现的字符串a |

| UPPER(s) 或 UCASE(s) | 将字符串s的所有字母转成大写字母 |

| LOWER(s) 或LCASE(s) | 将字符串s的所有字母转成小写字母 |

| LEFT(str,n) | 返回字符串str最左边的n个字符 |

| RIGHT(str,n) | 返回字符串str最右边的n个字符 |

| LPAD(str, len, pad) | 用字符串pad对str最左边进行填充,直到str的长度为len个字符 |

| RPAD(str ,len, pad) | 用字符串pad对str最右边进行填充,直到str的长度为len个字符 |

| LTRIM(s) | 去掉字符串s左侧的空格 |

| RTRIM(s) | 去掉字符串s右侧的空格 |

| TRIM(s) | 去掉字符串s开始与结尾的空格 |

| TRIM(s1 FROM s) | 去掉字符串s开始与结尾的s1 |

| TRIM(LEADING s1 FROM s) | 去掉字符串s开始处的s1 |

| TRIM(TRAILING s1 FROM s) | 去掉字符串s结尾处的s1 |

| REPEAT(str, n) | 返回str重复n次的结果 |

| SPACE(n) | 返回n个空格 |

| STRCMP(s1,s2) | 比较字符串s1,s2的ASCII码值的大小 |

| SUBSTR(s,index,len) | 返回从字符串s的index位置其len个字符,作用与SUBSTRING(s,n,len)、MID(s,n,len)相同 |

| LOCATE(substr,str) | 返回字符串substr在字符串str中首次出现的位置,作用于POSITION(substr IN str)、INSTR(str,substr)相同。未找到,返回0 |

| ELT(m,s1,s2,…,sn) | 返回指定位置的字符串,如果m=1,则返回s1,如果m=2,则返回s2,如果m=n,则返回sn |

| FIELD(s,s1,s2,…,sn) | 返回字符串s在字符串列表中第一次出现的位置 |

| FIND_IN_SET(s1,s2) | 返回字符串s1在字符串s2中出现的位置。其中,字符串s2是一个以逗号分隔的字符串 |

| REVERSE(s) | 返回s反转后的字符串 |

| NULLIF(value1,value2) | 比较两个字符串,如果value1与value2相等,则返回NULL,否则返回value1 |

注意:MySQL中,字符串的位置是从1开始的。

日期和时间函数


获取日期、时间

| 函数 | 用法 |

| — | — |

| CURDATE() ,CURRENT_DATE() | 返回当前日期,只包含年、月、日 |

| CURTIME() , CURRENT_TIME() | 返回当前时间,只包含时、分、秒 |

| NOW() / SYSDATE() / CURRENT_TIMESTAMP() / LOCALTIME() / LOCALTIMESTAMP() | 返回当前系统日期和时间 |

| UTC_DATE() | 返回UTC(世界标准时间)日期 |

| UTC_TIME() | 返回UTC(世界标准时间)时间 |

日期与时间戳的转换

| 函数 | 用法 |

| — | — |

| UNIX_TIMESTAMP() | 以UNIX时间戳的形式返回当前时间。SELECT UNIX_TIMESTAMP() ->1634348884 |

| UNIX_TIMESTAMP(date) | 将时间date以UNIX时间戳的形式返回。 |

| FROM_UNIXTIME(timestamp) | 将UNIX时间戳的时间转换为普通格式的时间 |

获取月份、星期、星期数、天数等函数

| 函数 | 用法 |

| — | — |

| YEAR(date) / MONTH(date) / DAY(date) | 返回具体的日期值 |

| HOUR(time) / MINUTE(time) / SECOND(time) | 返回具体的时间值 |

| MONTHNAME(date) | 返回月份:January,… |

| DAYNAME(date) | 返回星期几:MONDAY,TUESDAY…SUNDAY |

| WEEKDAY(date) | 返回周几,注意,周1是0,周2是1,。。。周日是6 |

| QUARTER(date) | 返回日期对应的季度,范围为1~4 |

| WEEK(date) , WEEKOFYEAR(date) | 返回一年中的第几周 |

| DAYOFYEAR(date) | 返回日期是一年中的第几天 |

| DAYOFMONTH(date) | 返回日期位于所在月份的第几天 |

| DAYOFWEEK(date) | 返回周几,注意:周日是1,周一是2,。。。周六是7 |

日期的操作函数

| 函数 | 用法 |

| — | — |

| EXTRACT(type FROM date) | 返回指定日期中特定的部分,type指定返回的值 |

EXTRACT(type FROM date)函数中type的取值与含义:

请添加图片描述

请添加图片描述

时间和秒钟转换的函数

| 函数 | 用法 |

| — | — |

| TIME_TO_SEC(time) | 将 time 转化为秒并返回结果值。转化的公式为:小时*3600+分钟*60+秒 |

| SEC_TO_TIME(seconds) | 将 seconds 描述转化为包含小时、分钟和秒的时间 |

计算日期和时间的函数

第1组:

| 函数 | 用法 |

| — | — |

| DATE_ADD(datetime, INTERVAL expr type),ADDDATE(date,INTERVAL expr type) | 返回与给定日期时间相差INTERVAL时间段的日期时间 |

| DATE_SUB(date,INTERVAL expr type),SUBDATE(date,INTERVAL expr type) | 返回与date相差INTERVAL时间间隔的日期 |

上述函数中type的取值:

请添加图片描述

第2组:

| 函数 | 用法 |

| — | — |

| ADDTIME(time1,time2) | 返回time1加上time2的时间。当time2为一个数字时,代表的是,可以为负数 |

| SUBTIME(time1,time2) | 返回time1减去time2后的时间。当time2为一个数字时,代表的是,可以为负数 |

| DATEDIFF(date1,date2) | 返回date1 - date2的日期间隔天数 |

| TIMEDIFF(time1, time2) | 返回time1 - time2的时间间隔 |

| FROM_DAYS(N) | 返回从0000年1月1日起,N天以后的日期 |

| TO_DAYS(date) | 返回日期date距离0000年1月1日的天数 |

| LAST_DAY(date) | 返回date所在月份的最后一天的日期 |

| MAKEDATE(year,n) | 针对给定年份与所在年份中的天数返回一个日期 |

| MAKETIME(hour,minute,second) | 将给定的小时、分钟和秒组合成时间并返回 |

| PERIOD_ADD(time,n) | 返回time加上n后的时间 |

日期的格式化与解析

| 函数 | 用法 |

| — | — |

| DATE_FORMAT(date,fmt) | 按照字符串fmt格式化日期date值 |

| TIME_FORMAT(time,fmt) | 按照字符串fmt格式化时间time值 |

| GET_FORMAT(date_type,format_type) | 返回日期字符串的显示格式 |

| STR_TO_DATE(str, fmt) | 按照字符串fmt对str进行解析,解析为一个日期 |

上述非GET_FORMAT函数中fmt参数常用的格式符:

| 格式符 | 说明 | 格式符 | 说明 |

| — | — | — | — |

| %Y | 4位数字表示年份 | %y | 表示两位数字表示年份 |

| %M | 月名表示月份(January,…) | %m | 两位数字表示月份(01,02,03。。。) |

| %b | 缩写的月名(Jan.,Feb.,…) | %c | 数字表示月份(1,2,3,…) |

| %D | 英文后缀表示月中的天数(1st,2nd,3rd,…) | %d | 两位数字表示月中的天数(01,02…) |

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
外链图片转存中…(img-AhmXtBg7-1715850277537)]

[外链图片转存中…(img-V4RfGMVl-1715850277537)]

[外链图片转存中…(img-HuGSDJVy-1715850277538)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值