当前位置: 首页 > news >正文

榆林公司网站建设产品市场推广方案范文

榆林公司网站建设,产品市场推广方案范文,wordpress 插件 活动,外贸五金网站文章目录 前言where介绍使用过滤结果集关联两个表 连接外连接内连接自然连接 使用inner join和直接使用where关联两个表的区别总结 前言 从数据库查询数据时,一张表不足以查询到我们想要的数据,更多的时候我们需要联表查询。 联表查询我们一般会使用连接…

文章目录

  • 前言
  • where
    • 介绍
    • 使用
      • 过滤结果集
      • 关联两个表
  • 连接
    • 外连接
    • 内连接
    • 自然连接
  • 使用inner join和直接使用where关联两个表的区别
  • 总结

前言

从数据库查询数据时,一张表不足以查询到我们想要的数据,更多的时候我们需要联表查询。

联表查询我们一般会使用连接,如inner join 、left join、right join 和 outer join等,但是个别时候也会使用where,接下来我们了解一下join on和where的区别

  • 我们创建两个表,student和class(忽略数据的多少啊,仅做举例使用)
    在这里插入图片描述

在这里插入图片描述

where

介绍

WHERE 是 SQL 中的一个关键字,用于在查询(如 SELECT、UPDATE 或 DELETE)中指定条件,以过滤出符合特定标准的数据。

  • WHERE 子句可以显著提高查询的效率,因为它限制了数据库处理的数据量。

使用

过滤结果集

  • 条件运算符 和 逻辑运算法的使用

    这里不多说了,不清楚的可以移步这里 →sql专题 之 常用命令

  • where和having的区别

    WHERE 子句只能指定行的条件,而不能指定组的条件
    HAVING 子句可以使用聚合函数,它用来指定组的条件

关联两个表

  • 查询所有的学生的信息包括其班主任名称

    select * FROM student,class WHERE student.class_id = class.id
    

    在这里插入图片描述

    相信这是大多数同学们第一次联表查询老师教的方法。
    通过关联student表中的class_id 和 class表中的id,我们获取了所有的信息。
    要知道from后的“student,class”功能可以说跟inner join一模一样。

  • where也能实现,为什么还有join on呢?

    虽然仅通过where关键字也可以进行联表查询,但是在sql中,还是需要各司其职比较好。毕竟where的定位是过滤筛选结果集。

    where拿手的是筛选,咱就别贪多嚼不烂了,联表查询还是交给join把~

连接

连接花样就多了,有外连接、内连接 和 自然连接

外连接

不仅包含符合连接条件的行,还会包括左表(左连接)、右表(右连接)或两个表中的所有数据行(全外连接)

  • 左连接

    左表为主表,左表中所有记录都会出现在结果集中,如果该行的字段在右表中没有匹配上,那么右表对应的字段以null填充

    select * FROM student left join class on student.class_id = class.id
    

    在这里插入图片描述

    left join 以左边的student表为基准,显示了表中没有class_id的数据,并以null填充。
    这样的好处是:不漏掉student表中任何一个数据

  • 右连接

    右表为主表,右表中所有记录都会出现在结果集中,如果该行的字段在左表中没有匹配上,那么左表对应的字段以null填充

    select * FROM student right join class on student.class_id = class.id
    

    在这里插入图片描述

    right join 以右边的class表为基准,id为4的班级没有学生信息录入,那扔以null填充
    坚决不漏掉class表中任意一个数据

内连接

只连接匹配的行。
即只有条件的交叉连接,会根据某个条件筛选出符合条件的记录。不符合条件的记录不会出现在结果集中

select * FROM student inner join class on student.class_id = class.id

在这里插入图片描述

看,就取这俩表的交集,谁也不特殊照顾~~

自然连接

自然连接是一种特殊的等值连接,它基于两个或多个表之间的共同字段自动进行连接。自然连接会自动选择那些在两个表中具有相同名称和兼容数据类型的字段作为连接条件

  • 两个表没有相同的字段

    select * from student NATURAL JOIN class
    

    如我们上边的表,两个表的字段没有相同的,那么结果就是一个笛卡尔积。运行结果同
    “select * from student cross join class”

  • 两个表有相同的字段

    我们对student表增加一个列“teacher”。
    在这里插入图片描述

    select * from student NATURAL JOIN class
    

    在这里插入图片描述

    这里特意试了一个小陷阱,会发现,在查询结果中,teacher列只出现了一列。说明仅仅是按照字段一模一样来匹配的。

在实际应用中,自然连接的使用相对较少,因为它可能不够灵活,并且可能导致意外的结果。通常,更推荐使用显式的JOIN操作符和ON子句来指定连接条件,这样可以更精确地控制连接行为。

使用inner join和直接使用where关联两个表的区别

  • 实现原理
    • INNER JOIN‌

      使用INNER JOIN时,连接条件放在ON子句中,这是一种显式连接。
      这种方式通过哈希表进行连接比较,效率较高‌。

    • WHERE子句

      使用WHERE子句进行连接时,连接条件放在WHERE子句中,这是一种隐式连接。
      这种方式先生成笛卡尔积,然后再进行过滤,效率较低‌。

  • 性能差异
    • INNER JOIN

      使用哈希表进行连接比较,其时间复杂度为O(LogN),效率较高。

    • WHERE子句‌

      由于先生成笛卡尔积再进行过滤,其时间复杂度为O(N^2),因此效率较低‌。

  • 使用场景
    • INNER JOIN‌

      适用于需要高效连接查询的场景
      特别是在连接条件较为复杂或需要结合多个连接条件时

    • WHERE子句‌

      适用于连接条件较为简单,且不需要显式连接操作的场景
      虽然效率较低,但在某些简单查询中仍然可以使用‌

总结

选择使用join on还是where取决于查询的具体需求和表的连接类型。

在内部连接中,‌join on和where的作用相似,‌可以互换使用。‌但在非内部连接中,‌尤其是使用left join on等连接类型时,‌on用于定义表之间的连接条件,‌而where则用于进一步筛选结果集中的记录。‌

总的来说,联表以后还是用连接查询吧😏😏😏

http://www.khdw.cn/news/68019.html

相关文章:

  • 视频网站是用什么框架做的常用的seo查询工具
  • iis添加网站 别名网络营销推广的5种方法
  • 网站被降权重新做网站昆明网站seo优化
  • 人与狗做的网站谁有网站建设黄页在线免费
  • 营销最好的方法郑州seo优化外包顾问阿亮
  • 让别人做网站需要提供什么seo网络优化培训
  • 南京网站推广费用郑州厉害的seo顾问公司
  • 网站建设和seo网盘资源搜索神器
  • 刚做淘客没有网站免费制作网站app
  • 性男女做视频观看网站十大网络推广公司排名
  • 武汉建筑设计院前10排名百度seo优化是什么
  • 南京网站推广费用seo关键词推广
  • 贸易公司怎么做网站比较好黑科技引流软件是真的吗
  • 打扑克网站推广软件品牌关键词优化
  • 怎么把网站上线优化网站技术
  • 服务器可以做几个网站吗网站排名怎么优化
  • 如何建立一个个人网站网络营销公司业务范围
  • html网页设计案例和代码企业网站seo贵不贵
  • 网站开发 占位符百度指数怎么查询
  • 网页设计叫什么岗位谷歌seo是什么
  • android移动开发免费网站分析seo报告是坑吗
  • 做网站除了买域名还有什么百度指数代表什么意思
  • 网站开发免责合同优化推广网站怎么做最好
  • 招聘网站排行榜六年级上册数学优化设计答案
  • 做营销网站建设挣钱吗全网推广怎么做
  • 谷歌网站怎么设置才能打开网站关键词排名优化提升培训
  • 瑞安电影城网站建设哪里有seo排名优化
  • 网页模板网站推荐代理怎么引流推广
  • 换接入商网站备案爱站网是什么
  • 网站集约化建设的意义网站首页快速收录