MySQL的连接查询

MySQL的连接查询

左表数据表结构

DROP TABLE IF EXISTS `employee_tbl`;
CREATE TABLE `employee_tbl` (
  `id` int(11) NOT NULL,
  `name` char(10) NOT NULL DEFAULT '',
  `date` datetime NOT NULL,
  `singin` tinyint(4) NOT NULL DEFAULT '0' COMMENT '登录次数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

右表数据表结构

CREATE TABLE IF NOT EXISTS `runoob_tbl`(
   `runoob_id` INT UNSIGNED AUTO_INCREMENT,
   `runoob_title` VARCHAR(100) NOT NULL,
   `runoob_author` VARCHAR(40) NOT NULL,
   `submission_date` DATE,
   PRIMARY KEY ( `runoob_id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
1. 左连接LEFT JOIN
SELECT * FROM employee_tbl e LEFT JOIN runoob_tbl r ON r.runoob_id=e.id;

​ 执行结果:

左连接


2. 右连接RIGHT JOIN
SELECT * FROM employee_tbl e RIGHT JOIN runoob_tbl r ON r.runoob_id=e.id;

​ 执行结果:
右连接


3. 内连接INNER JOIN
SELECT * FROM employee_tbl e INNER JOIN runoob_tbl r ON r.runoob_id=e.id;
(INNER JOIN可简写为JOIN)
等价于
SELECT * FROM employee_tbl e,runoob_tbl r WHERE r.runoob_id=e.id;

​ 执行结果:
内连接


总结:

左连接会获取左边表的所有数据,即使右表的没有匹配的数据;

右连接会获取右边表的所有数据,即使左表的没有匹配的数据;

内连接只会获取两个表中字段匹配关系的记录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值