博客
关于我
MySQL JOIN连接用法
阅读量:254 次
发布时间:2019-03-01

本文共 1827 字,大约阅读时间需要 6 分钟。

一、介绍join

SQL join用来把来自两个或多个表的行结合起来,下图展示了LEFT JOIN、RIGHT JOIN、INNER JOIN、OUTER JOIN相关的七种用法:

在这里插入图片描述
不同的SQL join之间的区别:

  • INNER JOIN:如果表中有至少一个匹配,则返回行
  • LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行
  • RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行
  • FULL JOIN:只要其中一个表中存在匹配,则返回行

二、代码例子

创建数据库:

create database if not exists test default charset utf8 collate utf8_general_ci;use test;SET NAMES utf8;SET FOREIGN_KEY_CHECKS = 0;DROP TABLE IF EXISTS `Websites`;CREATE TABLE `Websites` (  `id` int(11) NOT NULL,  `name` char(20) NOT NULL DEFAULT '',  `url` char(30) NOT NULL DEFAULT '',  `alexa` int(11) NOT NULL,  `country` char(10) NOT NULL DEFAULT '',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;DROP TABLE IF EXISTS `access_log`;CREATE TABLE `access_log` (  `aid` int(11) NOT NULL,  `site_id` int(11) NOT NULL,  `count` int(11) NOT NULL,  `date` datetime NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;BEGIN;INSERT INTO `Websites` VALUES ('1', 'Google', 'https://www.google.cm/', '1', 'USA'), ('2', 'TaoBao', 'https://www.taobao.cm/', '13', 'CN'), ('3', 'CaiNiao', 'https://www.runoob.cm/', '4689', 'CN'), ('4', 'Weibo', 'https://www.weibo.cm/', '20', 'CN'), ('5', 'Facebook', 'https://www.facebook.cm/', '3', 'USA'), ('7', 'stackoverflow', 'https://www.stackoverflow.cm/', '0', 'IND');COMMIT;BEGIN;INSERT INTO `access_log` VALUES ('1', '1', '45', '2016-05-10'), ('2', '3', '100', '2016-05-13'), ('3', '1', '230', '2016-05-14'), ('4', '2', '10', '2016-05-14'), ('5', '5', '205', '2016-05-14'), ('6', '4', '13', '2016-05-15'), ('7', '3', '220', '2016-05-15'), ('8', '5', '545', '2016-05-16'), ('9', '3', '201', '2016-05-17');COMMIT;

查看数据库:

在这里插入图片描述
在这里插入图片描述
在这两个表中,Websites表中的id列指向access_log表中的字段site_id,所以上面这两个表可以通过id和site_id联系起来。如果我们运行下面的SQL语句:

SELECT Websites.id, Websites.name, access_log.count, access_log.dateFROM WebsitesINNER JOIN access_logON Websites.id=access_log.site_id;

输出如下:

在这里插入图片描述

转载地址:http://xntx.baihongyu.com/

你可能感兴趣的文章
WebDriverException:未知错误:对于旧版本的 Google Chrome,在 Python 中找不到带有 Selenium 的 Chrome 二进制错误
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(2)~单表查询、mysql查询常用的函数
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>