使用数据处理函数
本章记录常用的mysql函数。
函数
与大多数编程语言一样,sql也支持函数来处理数据。就像上一章中的RTrim()函数。
关于可移植性:能运行在多个系统上的代码称为可移植的,虽然多数sql语言都是可以移植的,但是函数的移植性并不强,所以如果还不确定使用何种数据库的情况下,最好还是使用sql语句,尽量避免函数,因为各个DBMS的所支持的函数差异很大。当然函数会给我们带来便捷,为了以后考虑,在使用函数的地方注释尽量详尽一些。
使用函数
大多数SQL会支持以下类型的函数:
- 用于处理文本字符串的文本函数。比如删除或者填充,截取子串,转换大小写。
- 对数值进行算数操作的数学函数。比如代数运算。
- 用于处理日期和时间值,并从数值中提取特定成分的时间函数。比如返回两个日期的差。
- 返回DBMS正使用的特殊信息的系统函数。比如用户登录信息,返回版本信息等。
文本处理函数
比如我想让adress的所有值都是大写,可以用Upper()函数。
可以看到address列中的值都编程了大写,还可以优化一下,比如给这个大写的列取一个别名,方便调用。
取别名是一个好习惯,建议新生成一个列之后都取一个名字,方便调用。
书上列出的常见的文本处理函数如下:
我们选取几个常用的进行练习。
-
length()
- locate()
书里就给个函数名,我也不会用,于是我们得学会找资料,那么第一手资料必然是官方文档。
然后找到mysql官网的documention里,API传送门。当然,你可以在里面找到任何一个官方函数,剩下的就是看你的英文阅读能力了。
上图是官方API给出的解释。试着读一下。
locate()函数有两种重载形态,locate(substr, str), locate(substr, str, pos)
在看一下函数的解释,“第一个函数返回substr在str中第一次出现的位置,第二个函数返回str中substr第一次出现的位置,从pos位置开始搜索。如果str中没有substr子串则返回0。如果str或者substr为空,返回NULL”。
请看一下这两张图片中的第一条数据,当使用locate(substr, str, pos)函数时,pos设置的起始搜索位置是15,也就是从第15个字符开始往后搜索,发现没有匹配的值了,所以返回了0。
-
SubString()
看一下来自官方文档的截图:
SubString(str, pos):从pos的位置开始,截取后面的子串。
SubString(str From pos):跟上一个函数意思一样。
SubString(str, pos, len):从pos的位置开始,截取len个字符。
SubString(str FROM pos FOR len):跟上一个函数意思一样。
上图中还有几种很皮的用法,和python的list切片一样,也支持逆向索引。
比如SubString('abcde', -2),截取后两个字符,'de'。
SubString('abced', -3, 2),从倒数第3个字符开始截取,向后截取两个, 'ce'。
日期和时间处理函数
书中列出了如下的常用方法:
注意:在mysql中推荐的日期写法是,yyyy-mm-dd,虽然mysql支持两位数的年份,但是为了消除歧义应该使用四位数的年份,比如2018-01-12。
选取其中常用的进行测试练习:
-
Date() 提取日期和时间中的日期
在查询中经常按照日期进行查询,所以可以用Date()函数筛选。
实际情况也会只需要时间,那么就可以使用Time()函数。
按照时间查询也是同理的。
-
Year(), Month()
mysql还提供了提取年份和月份的函数,顾名思义就是返回时间的年份和月份。
比如,我想查询2016年9月份的订单信息。
书上给了两种方法,第一种是“硬编码”,每个月天数不一定,你很可能换个月份就要改sql代码了,所以,请使用第二种方法,也就是使用Year()和Month()函数来提取年份和月份,这样进行匹配的sql代码更灵活,适用性也更强。
数值处理函数
一般进行数学运算,反正我工作中基本没用过,但是还有瞅一眼,给大脑留个印象。
总结一下,这样讲述的函数比较多,但是常用的就那么几个,用的6了即可,剩下不常用的不会?看官方API,写的十分清楚而且还有示例,再次传送mysql 官方API
第十一章,OK。