首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql多表的关联查询

    1、多表关系 在数据表中,各个表结构之间存在着各种关系(一对一、一对多、多对多)。 一对一关系: 示例:学生与学生详情的关系,一个学生对应一个详细情况,一个详细情况对应一个学生。...实现:在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的UNIQUE。 一对多关系: 示例:学生与班级的关系,一个班级对应多个学生,一个学生对应一个班级。...实现:在多对多关系中,建立第三张中间表,中间表至少包含两个外键,分别关联两方主键 -- 一方,主表 CREATE TABLE dept( d_id INT PRIMARY KEY AUTO_INCREMENT...select * from dept,emp where dept.d_id=emp.d_id; # 2.注意事项: -- 1) 主表不能删除从表已引用的数据 DELETE from dept where...INSERT INTO emp (e_name, e_age, d_id) VALUES ('小王', 18, 3); -- 3) 先添加主表数据再添加从表数据 -- 也成主从表为父子表; -- 4) 先删除从表数据再删除主表数据

    7010

    MySQL百万级、千万级数据多表关联SQL语句调优

    本文不涉及复杂的底层数据结构,通过explain解释SQL,并根据可能出现的情况,来做具体的优化,使百万级、千万级数据表关联查询第一页结果能在2秒内完成(真实业务告警系统优化结果)。...1.使用explain语法,对SQL进行解释,根据其结果进行调优:      MySQL 表关联的算法是 Nest Loop Join,是通过驱动表的结果集作为循环基础数据,然后一条一条地通过该结果集中的数据作为过滤条件到下一个表中查询数据...来达到使用a.col上index的优化目的;或者使用left join且Where条件中不含b的过滤条件,此时的结果集为a的全集,而STRAIGHT_JOIN为inner join且使用a作为驱动表 3.多表...,使用left/right/inner join即可,根据explain优化;      b.有order by a.col条件时,所有join必须为left join,且每个join字段都创建索引,同时...c.STATUS = 58 and c.changed_type = 79 order by c.changed_time limit 1,10; 两者结果一致 4.误区:      a.视图只是屏蔽或者高效集合多表数据的一种方法

    2.6K20
    领券