首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql中的关联查询(内连接,外连接,连接)

在使用数据库查询语句时,单表的查询有时候不能满足项目的业务需求,在项目开发过程中,有很多需求都是要涉及到多表的连接查询,总结一下mysql中的多表关联查询 一,内连接查询 是指所有查询出的结果都是能够在连接的表中有对应记录的...: 此时,就要使用内连接查询,关键字(inner join) 在这里说一下关联查询sql编写的思路,1,先确定所连接的表,2,再确定所要查询的字段,3,确定连接条件以及连接方式 select e.empName...,如果右表没有记录对应的话就显示null 查询结果: 关键字是left outer join,等效于left join,在关联查询中,做外连接查询就是左连接查询,两者是一个概念 三,右外连接是同理的...: 如果在oracle中,直接就使用full outer join关键字连接两表就行了 五,连接查询 连接查询就是当前表与自身的连接查询,关键点在于虚拟化出一张表给一个别名 例如:查询员工以及他的上司的名称...所以,连接查询一般用作表中的某个字段的值是引用另一个字段的值,比如权限表中,父权限也属于权限。

3.7K40
您找到你想要的搜索结果了吗?
是的
没有找到

Django关联实现多级联动查询实例

1 问题引出 我们在开发网站的时候可能会遇到这种情况,多个字段之间有一定的关联性,比如省市县,选择省,之后下一个选择框的值则为该省的市集合,选择市之后下一个选择框的值为该市的县集合。...Django提供了关联的实现,模型自身关联,即一条数据关联另一条数据。 本文以省市县为案例介绍其具体实现方法。...verbose_name = ‘地址') pid = models.ForeignKey(‘self' , null = True, blank = True, verbose_name = ‘关联...') def __str__(self): return self.adress 说明: name :省市县的名字 pid:外键,self关联,这里也可以使用 AdressInfo...以上这篇Django关联实现多级联动查询实例就是小编分享给大家的全部内容了,希望能给大家一个参考。

2.3K10

Mybatis【17】-- Mybatis关联查询一对多查询

GitHub上,地址是:https://github.com/Damaer/Mybatis-Learning ,项目是mybatis-13-oneself-one2many,需要自取,需要配置maven环境以及mysql...docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 所谓关联查询,是指自己既然充当一方,又充当多方。...DB表如下: 查询指定栏目的所有子孙栏目 查询指定目录的所有子孙目录,我们需要使用递归的思想,查出当前栏目之后,需要将当前栏目的id作为下一级栏目的pid。...里面递归调用另一个sql,最外层的sql只执行一次,这样就可以实现查询自身一次,递归查询子孙栏目的功能: <!...org.apache.ibatis.transaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection

59120

Mybatis【17】-- Mybatis关联查询一对多查询

GitHub上,地址是:https://github.com/Damaer/Mybatis-Learning ,项目是mybatis-13-oneself-one2many,需要自取,需要配置maven环境以及mysql...docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 所谓关联查询,是指自己既然充当一方,又充当多方。...DB表如下: [29192b55571a01e02f992bad110400da.png] 查询指定栏目的所有子孙栏目 查询指定目录的所有子孙目录,我们需要使用递归的思想,查出当前栏目之后,需要将当前栏目的...里面递归调用另一个sql,最外层的sql只执行一次,这样就可以实现查询自身一次,递归查询子孙栏目的功能: <!...org.apache.ibatis.transaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.JDBC4Connection

88600

MySQL【三】---数据库查询详细教程{分页、连接查询关联、子查询、数据库设计规范}

】 3.关联 应用: 表示通过一张表实现逻辑关联查询,类似于省-市-县  关联自己关联自己: 数据下载链接: https://download.csdn.net/download/sinat...primary key, -> cid int, -> atitle varchar(20), -> pid int); show tables;  直接输入cmd 在此启动mysql...,再把这个结论当作条件再执行主语句; 对于:上面河北省关联可以采用子查询解决: select* from areas where pid = (select aid from areas where...atitle=" 河北省");  区别在于查询时间,子查询慢一点。...第三范式和第二范式有点像,从这张数据库表结构中可以看出,"姓名"、"年龄"、"学院"和主键"学号"直接关联,但是"学院地点"、"学院电话"却不直接和主键"学号"相关联,和"学院电话"直接相关联的是"学院

1.6K20

利用分析函数改写范围判断关联查询

= A.ROWID AND LENGTH(B.BEGIN) = LENGTH(A.BEGIN)); 如果分析 SQL语句,会发现这是一个关联语句,在BEGIN字段长度相等的前提下,想要找到那些不存在...业务的逻辑并不是特别复杂,但是要解决一条记录与其他记录进行比较,多半采用的方法是关联,而在这个关联中,既有大于等于又有小于等于,还有不等于,仅有的一个等于的关联条件,来自范围段 BEGIN的长度的比较...再来看一下具体的 SQL语句,会发现几乎没有办法建立索引,因为LENGTH(BEGIN)的选择度非常查,而其他的条件都是不等查询,选择度也不会好,即使建立索引,强制执行选择索引,效率也不会好。...对于关联查询而言,最佳的改写方法是利用分析函数,其强大的行级处理能力,可以在一次扫描过程中获得一条记录与其他记录的关系,从而消除了关联的必要性。...改写后,这个 SQL避免了关联,也就不存在关联条件重复值过高的性能隐患了。

68840

Mysql连接查询「建议收藏」

连接查询 假想以下场景:某一电商网站想要对站内产品做层级分类,一个类别下面有若干子类,子类下面也会有别的子类。...我们可以在数据库中创建两个字段来存储id和类别名称,使用第三个字段存储类别的子类或者父类的id,最后通过连接去查询想要的结果。...连接查询其实等同于连接查询,需要两张表,只不过它的左表(父表)和右表(子表)都是自己。做连接查询的时候,是自己和自己连接,分别给父表和子表取两个不同的别名,然后附上连接条件。...查询所有分类以及分类的父类:假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的parent_id等于父表的...查询所有分类以及分类的子类:还是假想有左右两张表(都是tdb_cates),左表是子表,右表是父表;查询子表的id,子表的cate_name,父表的cate_name;连接条件是子表的id等于父表的parent_id

1.4K20

Mybatis【18】-- Mybatis关联多对一查询方式

GitHub上,地址是:https://github.com/Damaer/Mybatis-Learning ,项目是mybatis-14-oneself-many2one,需要自取,需要配置maven环境以及mysql...docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 现在有个数据库查询需求,给出当前新闻栏目的id,希望查出父辈栏目,父辈的父辈栏目等等信息...(resultMap),resultMap的id是“newsLabelMapper”,“newsLabelMapper”中除了id映射和name映射,还有一个,里面定义的是关联关系定义...property="parent":表示映射的属性是parent javaType="NewsLabel":表示映射的类型是NewsLabel column="pid":使用pid作为参数传递进去再次查询...select="selectParentByParentId":查询 parent 属性执行的语句 <!

37930

Mybatis【18】-- Mybatis关联多对一查询方式

GitHub上,地址是:https://github.com/Damaer/Mybatis-Learning ,项目是mybatis-14-oneself-many2one,需要自取,需要配置maven环境以及mysql...docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 现在有个数据库查询需求,给出当前新闻栏目的id,希望查出父辈栏目,父辈的父辈栏目等等信息...(resultMap),resultMap的id是“newsLabelMapper”,“newsLabelMapper”中除了id映射和name映射,还有一个,里面定义的是关联关系定义...property="parent":表示映射的属性是parent javaType="NewsLabel":表示映射的类型是NewsLabel column="pid":使用pid作为参数传递进去,再次查询...select="selectParentByParentId":查询 parent 属性执行的 sql 语句 <!

30630

mysql如何执行关联查询与优化

mysql如何执行关联查询与优化 一、前言 在数据库中执行查询(select)在我们工作中是非常常见的,工作中离不开CRUD,在执行查询(select)时,多表关联也非常常见,我们用的也比较多,那么...mysql内部是如何执行关联查询的呢?...今天我们就来揭开mysql关联查询的神秘面纱。 二、mysql如何执行关联查询   mysql关联执行的策略很简单:mysql对任何关联都执行嵌套循环关联操作。...三、关联查询优化器   mysql优化器最重要的一部分就是关联查询优化,它决定了多个表关联时的顺序。通常多表关联的时候,可以有多种不同的关联顺序来获得相同的结果。...至此,mysql是如何进行关联查询的,以及优化,已经介绍完了,欢迎大家多多交流。

3.2K30

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券