SQL从入门到进阶跑 课件 第5章 玩转SQL函数与语法-数据的高级查询_第1页
SQL从入门到进阶跑 课件 第5章 玩转SQL函数与语法-数据的高级查询_第2页
SQL从入门到进阶跑 课件 第5章 玩转SQL函数与语法-数据的高级查询_第3页
SQL从入门到进阶跑 课件 第5章 玩转SQL函数与语法-数据的高级查询_第4页
SQL从入门到进阶跑 课件 第5章 玩转SQL函数与语法-数据的高级查询_第5页
已阅读5页,还剩6页未读 继续免费阅读

付费下载

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第5章玩转SQL函数与语法——数据的高级查询/05Contents1SQL常用函数23去重查询嵌套查询45关联查询合并查询67分组排序查询转置查询5.1SQL常用函数3MySQL内置了很多函数,包括数值函数、字符串函数、日期和时间函数、格式类型转换函数、条件判断函数、非空处理函数等。数值函数字符串函数日期函数其他函数ABSLENGTHCURRENT_DATE、CURDATECASTMODUPPER、LOWER、UCASE、LCASECURRENT_TIME、CURTIMECONVERTPOWER、POWCONCAT、CONCAT_WSNOW、CURRENT_TIMESTAMP、SYSDATEIFCEIL、CEILINGLEFT、RIGHTYEAR、QUARTER、MONTH、DAYCASEFLOORSUBSTRINGHOUR、MINUTE、SECONDIFNULL、COALESCERANDREPLACEDAYOFWEEK、DAYOFMONTH、DAYOFYEARNULLIFROUNDINSERTWEEK、WEEKOFYEARISNULLTRUNCATEINSTR、POSITION、LOCATEWEEKDAYTRIMMONTHNAME、DAYNAMEREVERSEDATE_ADD、ADDDATEDATE_SUB、SUBDATETIMESTAMPADDADDTIME、SUBTIMEDATEDIFF、TIMEDIFFTIMESTAMPDIFFDATE、TIME、TIMESTAMPDATE_FORMAT、TIME_FORMAT

UNIX_TIMESTAMP、FROM_UNIXTIME

表1MySQL常用函数MySQL常用函数如下所示:5.2去重查询4当从数据表中查询出来的行数据(单列或多列)出现重复时,可以使用DISTINCT关键字进行去重查询,针对重复的行数据仅保留其中一条。DISTINCT语法格式如下所示:示例:查询门店电器用户信息表store_appliance_userinfo中所有客户的不同省份。5.3嵌套查询5在一段SQL查询脚本中嵌套了一个或多个查询,嵌套的查询语句通常叫作子查询语句。子查询语句可以分为两种类型,一种类型是相关子查询,另外一种类型是不相关子查询。示例:查询门店电器用户信息表store_appliance_userinfo中年龄高于所有人平均年龄的客户信息。5.3.1常量值的子查询下面主要针对不相关子查询进行详细讲解。示例:查询门店电器用户信息表store_appliance_userinfo中人数大于等于2人对应的省份个数。5.3.2表的子查询5.4关联查询6关联查询指的是将两个或两个以上的表连接起来进行查询,多表通过连接进行列合并生成一张总表,连接后的总表可以作为一张全新的表来查询。MySQL中的关联查询主要分为三种类型,分别是:内关联([INNER]JOIN)、左关联(LEFTJOIN)、右关联(RIGHTJOIN)。三种关联的语法基本一致,语法格式如下所示:除了上面三种关联类型之外,还可以衍生出四种关联查询。5.5合并查询7合并查询指的是数据的行合并查询。在SQL语法中通常使用UNION或UNIONALL关键字来实现数据的行合并操作,SQL合并查询语法如下所示:示例:查询门店电器用户信息表store_appliance_userinfo中男性与女性的所属省份,并将所属省份数据行合并到一起(去重)。5.5.1去重合并查询去重合并查询使用的是UNION关键字,通过UNION将两个或者多个SELECT查询语句返回的结果集在垂直方向合并到一起,并实现去重操作。5.5合并查询8示例:查询门店电器用户信息表store_appliance_userinfo中男性与女性的所属省份,并将所属省份数据行合并到一起(不去重)。5.5.2不去重合并查询不去重合并查询使用的是UNIONALL关键字,通过UNIONALL将两个或者多个SELECT查询语句返回的结果集在垂直方向合并到一起,行合并之后的数据不会进行去重操作。5.6分组排序查询9MySQL在8.0版本之后新增了几个窗口函数,可以帮助解决分组后不同组内的排序问题。这里涉及排序的窗口函数主要有RANK、DENSE_RANK、ROW_NUMBER。它们的相同点与不同点如下所示:5.6分组排序查询10SQL分组排序查询函数语法如下所示:示例:查询门店电器用户信息表store_appliance_userinfo中的客户信息以及年龄从高到低的排序(三种排序方式)。5.7转置查询11查询有时需要将表进行转置,将原数据中的某一列作为维度转换为列标题。MySQL中借助于CASE…WHEN

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论