• Join查询


    join主要根据两表或多表之间列的关系,从这些表中进行数据的查询。

    首先创建两张表:tb_emp(员工表)和tb_dept(部门表),并插入相关测试数据。

    1)tb_emp表。

    DROP TABLE IF EXISTS `tb_emp`;
    CREATE TABLE `tb_emp` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(20) NOT NULL,
      `deptid` int(11) NOT NULL,
      PRIMARY KEY (`id`),
      KEY `idx_tb_emp_name` (`name`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    INSERT INTO `tb_emp`(name,deptid) VALUES ('jack', '1');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('tom', '1');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('tonny', '1');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('mary', '2');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('rose', '2');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('luffy', '3');
    INSERT INTO `tb_emp`(name,deptid) VALUES ('outman', '14');

    2)tb_dept表。

    DROP TABLE IF EXISTS `tb_dept`;
    CREATE TABLE `tb_dept` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `deptname` varchar(20) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    INSERT INTO `tb_dept`(deptname) VALUES ('研发');
    INSERT INTO `tb_dept`(deptname) VALUES ('测试');
    INSERT INTO `tb_dept`(deptname) VALUES ('运维');
    INSERT INTO `tb_dept`(deptname) VALUES ('经理');

    从上表插入的数据可知outman是没有对应部门的。

    一、inner join

    注:A表示左表,B表示右表,下同。

    inner join:A、B共有,也就是交集

    二、left join

    left jion:A独有+AB共有(交集)

    三、right join

    right join:B独有+AB共有(交集)

    四、A独有

    注:参照left join,A独有只是将AB交集部分去掉。

    五、B独有

    注:参照right join,B独有只是将AB交集部分去掉。 

    六、AB全有(并集)

    由于mysql中不支持full outer join,所以这里通过union进行转换。AB并集:AB交集+A独有+B独有

    七、A、B独有并集

    A、B独有并集,相当于A、B全有去掉AB的共有(交集)。

    注意:MySQL不支持full outer join,所以需要对其进行转换变形,最终达到效果。

    转自:https://www.cnblogs.com/developer_chan/p/9207687.html

    时刻与技术进步,每天一点滴,日久一大步!!! 本博客只为记录,用于学习,如有冒犯,请私信于我。
  • 相关阅读:
    制作keil5的pack
    【转】链接脚本(1)
    mongodb数据到MySQL数据库 的迁移步骤
    mongo副本集设置主库权重,永远为主
    mongodb副本集的从库永久性设置setSlaveOk
    Ubuntu系统查看mongo得慢日志,及一些操作
    Ubuntu系统下手动释放内存
    linux下面得小数计算
    Syncthing搭建
    ubuntu搭建ftp服务器
  • 原文地址:https://www.cnblogs.com/myitnews/p/13696098.html
Copyright © 2020-2023  润新知