美文网首页
必知必会-第十一章

必知必会-第十一章

作者: 转身丶即天涯 | 来源:发表于2018-01-17 15:18 被阅读9次

使用数据处理函数

本章记录常用的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。

相关文章

  • 必知必会-第十一章

    使用数据处理函数 本章记录常用的mysql函数。 函数 与大多数编程语言一样,sql也支持函数来处理数据。就像上一...

  • 附录3、Docker-compose 命令使用指南

    本文是《Docker必知必会系列》第十一篇,原文发布于个人博客:悟尘纪。上一篇:Docker必知必会系列(附录2)...

  • 附录4、Docker-compose 配置文件编写指南

    本文是《Docker必知必会系列》第十二篇,原文发布于个人博客:悟尘纪。上一篇:Docker必知必会系列(附录3)...

  • 附录2、Dockerfile 参考及最佳实践

    本文是《Docker必知必会系列》第十篇,原文发布于个人博客:悟尘纪。上一篇:Docker必知必会系列(附录1):...

  • 优秀参考文章--性能优化

    Android 性能优化必知必会Android 性能优化必知必会

  • 必知必会

    1、斜杠(/)和反斜杠(\) 文件路径 统一使用 / (斜杠)与网址路径保持一致。在有些特殊的情况下,灵活变通。事...

  • 书籍归档

    PHP入门到精通(朋友赠送) 正则表达式必知必会(朋友赠送) SQL必知必会(朋友赠送) Docker技术入门与实...

  • SQL必知必会

    《SQL必知必会》SQL是使用 广泛的数据库语言,几乎所有重要的DBMS都支持SQL。《SQL必知必会(第4版)》...

  • 必知必会-第十三章

    分组数据 本章介绍如何分组数据,两个关键字GROUP BY和HAVING。 分组的作用 分组允许把数据分为多个逻辑...

  • 《SQL必知必会 第4版》PDF高清完整版-免费下载

    《SQL必知必会 第4版》PDF高清完整版-免费下载 《SQL必知必会 第4版》PDF高清完整版-免费下载 下载地...

网友评论

      本文标题:必知必会-第十一章

      本文链接:https://www.haomeiwen.com/subject/psfdoxtx.html