深入浅出存储引擎 配套课件.ppt

深入浅出存储引擎 配套课件.ppt

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

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_userinfo中的客户信息以及年龄从高到低的排序(三种排序方式)。5.7转置查询*查询有时需要将表进行转置,将原数据中的某一列作为维度转换为列标题。MySQL中借助于CASE…WHEN、IF、聚合函数(MAX、MIN、SUM、AVG)来实现转置查询。示例:将左边表的数据转置成右边表的数据,这里就用到了转置操作,需要将prodName字段作为维度转换为列标题。具体实现脚本如下:第6章封装SQL语句的表——视图的增删及查询Contents1视图的创建23视图的删除视图的修改4视图的查询第6章封装SQL语句的表——视图的增删及查询*视图(View)是一种虚拟存在的表,但视图并不实际存在于数据库中。视图也是由列和行构成,行和列的数据来自于定义视图的查询中所使用的表,并且还是在使用视图时动态生成的。视图相对于普通表的优势在于以下几点:6.1视图的创建*基于单张表的数据查询而创建的视图称为单表视图的创建。6.1.1单表视图的创建示例:创建成功一个名为view_loan_userinfo的视图。A部门只看到的客户字段信息为姓名、性别和年龄,B部门只看到的客户字段信息为姓名、学历和收入,C部门只看到的是地区为Florida且客户字段信息为姓名、是否有房产和是否有车。根据ABC部门不同的需求来创建不同的视图。6.1视图的创建*基于多张表的数据查询而创建的视图称为多表视图的创建。6.1.2多表视图的创建示例:将贷款用户信息表loan_userinfo与贷款业务明细表loan_details两张表作为源表来创建一张视图,创建完成后的视图字段包括custID、custName、income、orderDate、prodName、amount。创建语法如下所示:执行完上段SQL脚本,数据库中就会创建成功一张多表视图,通过关键字DESC可以查看视图结构。6.2视图的删除*视图的删除是通过关键字DROPVIEW来实现的,既可以一次删除一张视图,也可以一次删除多张视图。删除视图的语法如下所示:示例:一次删除一张视图view_loan_userinfo和一次删除三张视图view_loan_userinfo_a、view_loan_u

文档评论(0)

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

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

版权声明书
用户编号:5213302032000001

1亿VIP精品文档

相关文档