深入浅出存储引擎 第5章 玩转SQL函数与语法 数据的高级查询.ppt

深入浅出存储引擎 第5章 玩转SQL函数与语法 数据的高级查询.ppt

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

www.islide.cc第5章玩转SQL函数与语法——数据的高级查询Contents1SQL常用函数23去重查询嵌套查询45关联查询合并查询67分组排序查询转置查询5.1SQL常用函数*MySQL内置了很多函数,包括数值函数、字符串函数、日期和时间函数、格式类型转换函数、条件判断函数、非空处理函数等。数值函数字符串函数日期函数其他函数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_FORMATUNIX_TIMESTAMP、FROM_UNIXTIME表1MySQL常用函数MySQL常用函数如下所示:5.2去重查询*当从数据表中查询出来的行数据(单列或多列)出现重复时,可以使用DISTINCT关键字进行去重查询,针对重复的行数据仅保留其中一条。DISTINCT语法格式如下所示:示例:查询门店电器用户信息表store_appliance_userinfo中所有客户的不同省份。5.3嵌套查询*在一段SQL查询脚本中嵌套了一个或多个查询,嵌套的查询语句通常叫作子查询语句。子查询语句可以分为两种类型,一种类型是相关子查询,另外一种类型是不相关子查询。示例:查询门店电器用户信息表store_appliance_userinfo中年龄高于所有人平均年龄的客户信息。5.3.1常量值的子查询下面主要针对不相关子查询进行详细讲解。示例:查询门店电器用户信息表store_appliance_userinfo中人数大于等于2人对应的省份个数。5.3.2表的子查询5.4关联查询*关联查询指的是将两个或两个以上的表连接起来进行查询,多表通过连接进行列合并生成一张总表,连接后的总表可以作为一张全新的表来查询。MySQL中的关联查询主要分为三种类型,分别是:内关联([INNER]JOIN)、左关联(LEFTJOIN)、右关联(RIGHTJOIN)。三种关联的语法基本一致,语法格式如下所示:除了上面三种关联类型之外,还可以衍生出四种关联查询。5.5合并查询*合并查询指的是数据的行合并查询。在SQL语法中通常使用UNION或UNIONALL关键字来实现数据的行合并操作,SQL合并查询语法如下所示:示例:查询门店电器用户信息表store_appliance_userinfo中男性与女性的所属省份,并将所属省份数据行合并到一起(去重)。5.5.1去重合并查询去重合并查询使用的是UNION关键字,通过UNION将两个或者多个SELECT查询语句返回的结果集在垂直方向合并到一起,并实现去重操作。5.5合并查询*示例:查询门店电器用户信息表store_appliance_userinfo中男性与女性的所属省份,并将所属省份数据行合并到一起(不去重)。5.5.2不去重合并查询不去重合并查询使用的是UNIONALL关键字,通过UNIONALL将两个或者多个SELECT查询语句返回的结果集在垂直方向合并到一起,行合并之后的数据不会进行去重操作。5.6分组排序查询*MySQL在8.0版本之后新增了几个窗口函数,可以帮助解决分组后不同组内的排序问题。这里涉及排序的窗口函数主要有RANK、DENSE_RANK、ROW_NUMBER。它们的相同点与不同点如下所示:5.6分组排序查询*SQL分组排序查询函数语法如下所示:示例:查询门店电器用户信息表store_appliance_useri

文档评论(0)

dllkxy + 关注
实名认证
内容提供者

本文库主要涉及建筑、教育等资料,有问题可以联系解决哦

版权声明书
用户编号:5213302032000001

1亿VIP精品文档

相关文档