首页 > 数据库技术 > 详细

我的MYSQL学习笔记(四)——函数

时间:2015-03-22 22:25:28      阅读:290      评论:0      收藏:0      [点我收藏+]

数字函数
1、求余函数MOD(X,Y)

MOD(X,Y)返回x被y除后的余数,MOD()对于带有小数部分的数值也起作用,他返回除法运算后的精确余数
技术分享
2、函数TRUNCATE(X,Y)

TRUNCATE(X,Y)返回被舍去至小数点后y位的数字x。若y的值为0,则结果不带有小数点或不带有小数部分。
技术分享

若y设为负数,则截去(归零)x小数点左边起第y位开始后面所有低位的值。
技术分享
TIPS:ROUND(X,Y)函数在截取值的时候会四舍五入,而TRUNCATE(x,y)直接截取值,并不进行四舍五入
3、HEX(N)
 把N转为十六进制并以字串返回(N是BIGINT数字,等价于CONV
(N,10,16))
技术分享
UNHEX是HEX的反转函数
技术分享

字符函数
1、CHAR_LENGTH(STR)返回值为字符串str所包含的字符个数。一个多字节字符算作一个单字符
技术分享
2、合并字符串函数CONCAT_WS(x,s1,s2,……)

CONCAT_WS(x,s1,s2,……),CONCAT_WS代表CONCAT with Separator,是CONCAT()函数的特殊形式。

第一个参数x是其他参数的分隔符,分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是

其他参数。如果分隔符为NULL,则结果为NULL。函数会忽略任何分隔符参数后的NULL值。
技术分享
3、INSERT(str,pos,len,newstr)
返回字符串str,在位置pos起始的子串且len个字符长得子串由字符串newstr代替
技术分享
4、填充字符串的函数LPAD(S1,LEN,S2)和RPAD(S1,LEN,S2)

LPAD(S1,LEN,S2)返回字符串s1,其左边由字符串s2填补到len字符串长度。假如s1的长度大于len,则返回值被缩短至len字符。
技术分享
技术分享
注意上面两幅图的区别
5、删除空格的函数TRIM(S)
TRIM(S)删除字符串s两侧的空格
技术分享
6、TRIM(S1 FROM S)删除字符串s中两端所有的子字符串s1。s1为可选项,在未指定情况下,删除空格。这个函数时删除字符串两端相应匹配的字符,字符串中间出现的响应字符是不会被去除的。
技术分享
7、重复生成字符串的函数REPEAT(S,N)
技术分享
8、比较字符串大小的函数STRCMP(S1,S2)
STRCMP(S1,S2)若所有的字符串均相同,则返回0;若根据当前分类次序,第一个参数小于第二个,则返回-1,其他情况返回1
技术分享
9、匹配子串开始位置的函数

LOCATE(STR1,STR)、POSITION(STR1 IN STR)、INSTR(STR,STR1)3个函数作用相同,返回子字符串str1在字符串str中的开始位置

技术分享
10、返回指定位置的字符串的函数

ELT(N,字符串1,字符串2,字符串3,…,),若N=1,则返回值为字符串1,若N=2,则返回值为字符串2,以此类推。指定返回字符串位置超出参数个数,返回NULL
技术分享
11、返回指定字符串位置的函数FIELD(S,S1,S2,…)

FIELD(S,S1,S2,…)返回字符串s在列表s1,s2,……中第一次出现的位置,在找不到s的情况下,返回值为0。

如果s为NULL,则返回值为0,原因是NULL不能同任何值进行同等比较。
技术分享
12、返回子串位置的函数FIND_IN_SET(S1,S2)
FIND_IN_SET(S1,S2)返回字符串s1在字符串列表s2中出现的位置,字符串列表是一个由多个逗号‘,’分开的字符串组成的列表。如果s1不在s2或s2为空字符串,则返回值为0。如果任意一个参数为NULL,则返回值为NULL。这个函数在第一个参数包含一个逗号‘,’时将无法正常运行。
技术分享
13、选取字符串的函数MAKE_SET(X,S1,S2,…)

MAKE_SET(X,S1,S2,…)返回由x的二进制数指定的相应位的字符串组成的字符串,s1对应比特1,s2对应比特01以此类推。
技术分享
1的二进制值为0001,4的二进制值为0100,1与4进行异或操作之后的二进制值为0101,从右到左第一位和第三位为1。

MAKE_SET(1,’a’,’b’,’c’)返回第一个字符串

MAKE_SET(1|4,’hello’,’nice’,’world’) 返回从左端开始第一和第三个字符串组成的字符串

日期和时间函数
1、获取当前日期的函数和获取当前时间的函数
CURDATE()、CURRENT_DATE()、CURRENT_TIMESTAMP()、LOCALTIME()、NOW()、SYSDATE()、utc_time(),UTC_TIMESTAMP()
技术分享
2、获取月份的函数MONTHNAME(DATE)

MONTHNAME(DATE)函数返回日期date对应月份的英文全名
技术分享
3、获取季度、分钟和秒钟的函数

QUARTER(DATE)返回date对应的一年中的季度值,范围是从1~4

使用QUARTER(DATE)函数返回指定日期对应的季度
技术分享
MINUTE(TIME)返回time对应的分钟数,范围是从0~59
技术分享
SECOND(time) 返回time对应的秒数,范围是从0~59
技术分享
4、获取日期的指定值的函数EXTRACT(type FROM date)

EXTRACT(type FROM date)这个函数跟SQLSERVER里的DATEPART()函数是一样的
技术分享
5、时间和秒钟转换的函数
TIME_TO_SEC(time)返回已转化为秒的time参数,转换公式为:小时*3600+分钟*60+秒
SEC_TO_TIME(second)函数可以将秒转换为小时、分钟和秒数的second参数值
技术分享
6、计算日期和时间的函数

MYSQL里计算日期和时间的函数比较多

增加日期:DATE_ADD(date,interval expr type),ADDDATE(date,interval expr type)注意interval关键字
技术分享

减去日期:DATE_SUB(date,interval expr type),SUBDATE(date,interval expr type)
技术分享
增加时间:ADD_TIME(date,expr)

减去时间:SUBTIME(date,expr)
技术分享

我的MYSQL学习笔记(四)——函数

原文:http://blog.csdn.net/junshuaizhang/article/details/44126561

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!