必知必会-第十一章

使用数据处理函数

本章记录常用的mysql函数。

函数

与大多数编程语言一样,sql也支持函数来处理数据。就像上一章中的RTrim()函数。

关于可移植性:能运行在多个系统上的代码称为可移植的,虽然多数sql语言都是可以移植的,但是函数的移植性并不强,所以如果还不确定使用何种数据库的情况下,最好还是使用sql语句,尽量避免函数,因为各个DBMS的所支持的函数差异很大。当然函数会给我们带来便捷,为了以后考虑,在使用函数的地方注释尽量详尽一些。

使用函数

大多数SQL会支持以下类型的函数:

  • 用于处理文本字符串的文本函数。比如删除或者填充,截取子串,转换大小写。
  • 对数值进行算数操作的数学函数。比如代数运算。
  • 用于处理日期和时间值,并从数值中提取特定成分的时间函数。比如返回两个日期的差。
  • 返回DBMS正使用的特殊信息的系统函数。比如用户登录信息,返回版本信息等。
文本处理函数

比如我想让adress的所有值都是大写,可以用Upper()函数。


image.png

可以看到address列中的值都编程了大写,还可以优化一下,比如给这个大写的列取一个别名,方便调用。


image.png

取别名是一个好习惯,建议新生成一个列之后都取一个名字,方便调用。

书上列出的常见的文本处理函数如下:


image.png

image.png

我们选取几个常用的进行练习。

  • length()


    image.png
  • locate()
    书里就给个函数名,我也不会用,于是我们得学会找资料,那么第一手资料必然是官方文档。
    然后找到mysql官网的documention里,API传送门。当然,你可以在里面找到任何一个官方函数,剩下的就是看你的英文阅读能力了。
image.png

上图是官方API给出的解释。试着读一下。
locate()函数有两种重载形态,locate(substr, str), locate(substr, str, pos)
在看一下函数的解释,“第一个函数返回substr在str中第一次出现的位置,第二个函数返回str中substr第一次出现的位置,从pos位置开始搜索。如果str中没有substr子串则返回0。如果str或者substr为空,返回NULL”。


image.png

image.png

请看一下这两张图片中的第一条数据,当使用locate(substr, str, pos)函数时,pos设置的起始搜索位置是15,也就是从第15个字符开始往后搜索,发现没有匹配的值了,所以返回了0。

  • SubString()
    看一下来自官方文档的截图:


    image.png

    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'。

日期和时间处理函数

书中列出了如下的常用方法:


image.png
注意:在mysql中推荐的日期写法是,yyyy-mm-dd,虽然mysql支持两位数的年份,但是为了消除歧义应该使用四位数的年份,比如2018-01-12。

选取其中常用的进行测试练习:

  • Date() 提取日期和时间中的日期


    image.png

    image.png

在查询中经常按照日期进行查询,所以可以用Date()函数筛选。


image.png

实际情况也会只需要时间,那么就可以使用Time()函数。


image.png

按照时间查询也是同理的。


image.png
  • Year(), Month()
    mysql还提供了提取年份和月份的函数,顾名思义就是返回时间的年份和月份。
    比如,我想查询2016年9月份的订单信息。


    image.png

    书上给了两种方法,第一种是“硬编码”,每个月天数不一定,你很可能换个月份就要改sql代码了,所以,请使用第二种方法,也就是使用Year()和Month()函数来提取年份和月份,这样进行匹配的sql代码更灵活,适用性也更强。

数值处理函数

一般进行数学运算,反正我工作中基本没用过,但是还有瞅一眼,给大脑留个印象。


image.png

总结一下,这样讲述的函数比较多,但是常用的就那么几个,用的6了即可,剩下不常用的不会?看官方API,写的十分清楚而且还有示例,再次传送mysql 官方API

第十一章,OK。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容