- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库中的连接.ppt
第7章 多表连接查询 重点内容: SQL连接语法 连接的处理步骤 连接的类型 * SQL实用简明教程 * 新世纪网页设计师应用教程 第1章 网页设计基础 重点内容: 网页的设计构思和布局 站点的规划与设计流程 主页的基本制作流程 SELECT select_list FROM Table1name [CROSS | NATURAL] JOIN Table2name [ON [Table1name.]column operator [Table2name.]column] [WHERE conditions] 一、连接的语法 SQL中为连接提供了关键字JOIN、CROSS JOIN及NATURAL JOIN,用于连接操作。 第一行中的select_list仍然是选择的列的名称,但是需要注意的是,如果使用两个表中有相同名称的列,则必须限定是哪个表中的列; 第二行中关键字CROSS与NATURAL是可选项,可以使用也可以不使用。如果选择了CROSS或NATURAL关键字,那么就不能使用ON关键字; 单独使用JOIN关键字时,需要使用ON关键字来设定连接的条件; 使用CROSS JOIN时,不能使用关键字ON,因此必须使用WHERE子句设定连接的条件。因为如果不设定连接条件,将返回表之间的每一种可能组合(即笛卡尔积),连接结果将非常庞大; NATURAL JOIN只有在两个表有相同名称的列时才能使用,将在同名列上进行连接。因此,不必使用关键字ON或WHERE子句设定连接条件。当然,使用WHERE子句限制查找的行仍然是可以的。 二、使用连接的原因 连接是关系模型的关键操作,因为表之间的数据并不是互不相关的,而是存在一定的联系的,数据库中仅仅知道各表单独的数据是不足够的。这时就需要通过连接来发现数据之间的关系,找出数据之间的联系,而不仅仅局限于数据库中已有的一些关系。 使用连接还有一个好处:连接对于结果没有特别的限制,具有很大的灵活性。通常可以通过连接创建包含不同表中数据的新表或者视图。这就使得数据库的扩展具有很大的灵活性。 三、处理连接的方法 1、笛卡儿积 有的时候,由于连接条件设置的不好,甚至没有设置连接条件,结果将包含太多的行。这是由于笛卡尔积造成的。从概念上说,连接首先将形成表的笛卡尔积,即形成用于连接的表中所有的行的组合。 用于连接的表越多,其笛卡尔积的结果将越大,越需要很好的指定连接条件。当然,在一些特殊情况下,如一个表中只包含一个记录时,可以不指定连接条件。因为这时的笛卡尔积是另外一个表中记录的个数。 进行连接操作时,都是先形成表之间的笛卡尔积,获得笛卡尔积之后再使用指定的连接条件及WHERE子句中其它的限制条件对形成的笛卡尔积进行删除,保留符合条件的记录。正确的指定连接条件和限制条件将有助于产生良好的连接结果。当返回的结果过多时,请注意检查连接条件是否合适。 此外,由于连接过程中使用了笛卡尔积,因此连接操作会导致性能的下降。因此,在使用时最好遵循以下一些原则: (1)用于连接的列已经创建了索引。因为索引会单独保存在磁盘上,且将数据按照一定顺序进行了排列,索引的使用可以加快访问的速度; (2)用于连接的列具有相同的数据类型,包括是否允许空值。如果需要系统自动进行类型转换是需要花费较多时间的,特别是在表中记录很多时,类型转换所花费的时间将会很多. 三、处理连接的方法 2、连接中运算符的使用 在进行连接时,可以使用前面介绍的运算符指定连接的条件。最常见的是使用等号进行连接,也可以使用大于或小于等其它运算符进行连接操作。此外,在进行连接时,还可以使用WHERE子句限制查找的行。 3、多表连接 在FROM子句中添加表名,在连接条件中设定新的连接条件即可实现多表连接。在多表连接时也可以使用JOIN关键字,不过用起来比较繁琐,不如FROM/WHERE来的简便。多表连接一个很重要的应用就是结合连接表进行使用。 三、处理连接的方法 4、连接结果的处理 在进行连接时,也可以为表或列创建别名以方便使用或使显示结果更加清晰。特别是表中有相同名称的列时,别名的使用可以使代码更易于输入,且更易于阅读。 使用别名 如果连接表的连接列中存在NULL时,NULL将不会参与连接,即使两个表的连接列都存在NULL,连接结果也不会存在NULL。因为,空值代表的是未知、丢失或不可用的值,所以连接时不会对空值进行连接。 空值的处理 返回连接结果时,不一定要显示用于连接的列。需要显示时,也应该注意不要出现重复。 删除重复 当使用连接来连接多个表时,一般来说都不会使用“*”来选择所有的列,而是在SELECT
您可能关注的文档
- 教育人性化的总体化实践.pdf
- 教育基本法对教育行政机关的影响及其因应之道.pdf
- 教育实验中的副效应.pdf
- 教育游戏的国内外研究综述.pdf
- 散发性结直肠癌D10S1265位点的杂合缺失分析.pdf
- 散文阅读之思路、结构1.ppt
- 敦煌大宝胶囊对肾阳虚小鼠抗应激作用影响的研究.pdf
- 敦煌石室大宝胶囊对衰老大鼠脑组织钙稳态的影响.pdf
- 数值计算方法在凸轮设计与优化中的应用.pdf
- 数字PID控制算法53591.ppt
- 工程建筑隔墙板施工方案(3篇).docx
- 2025年黑龙江省大兴安岭地区行政职业能力测验题库及答案1套.docx
- 2025年黑龙江省大兴安岭地区行政职业能力测验模拟试题推荐.docx
- 小班健康课件模板图片.pptx
- 2023年度一级建造师题库检测试题打印附参考答案详解(夺分金卷).docx
- 2025年黑龙江省大兴安岭地区行政职业能力测验题库最新.docx
- 2025年黑龙江省哈尔滨市行政职业能力测验题库附答案.docx
- 2025年黑龙江省大兴安岭地区行政职业能力测验模拟试题最新.docx
- 2023年度一级建造师题库试题及参考答案详解【名师推荐】.docx
- 2025年黑龙江省哈尔滨市行政职业能力测验题库最新.docx
文档评论(0)