多表查询(内连接,外连接)

/*

拥有朋友(字段)
*/

-- 创建数据库
drop database if exists mydb;
create database mydb character set utf8;
use mydb;

-- 创建Person表
/*
# 不符合第一范式
# 家乡字段:不符合第一范式(列不可再分,列的原子性)
# 可以把“河南省郑州市”分为两个字段“河南省”“郑州市”

create table person(
pid int primary key auto_increment, -- 编号
pname varchar(20) not null, -- 姓名
psex char(2) default "男", -- 性别
page int not null, -- 年龄
pfriends varchar(100), -- 朋友
phome varchar(100) -- 家乡
);
insert into person values
(null,'张三',default,20,'李四,王五,赵六','河南省郑州市');
*/
-- 一个人,多个朋友,属于一个字段带多个数据
-- 再设计一个表作为朋友表(通过外键来设计关系)
create table person(
pid int primary key auto_increment, -- 编号
pname varchar(20) not null, -- 姓名
psex char(2) default "男", -- 性别
page int not null, -- 年龄
pfriends varchar(100), -- 朋友
sheng varchar(50), -- 省
shi varchar(50) -- 市
);
-- 朋友表
CREATE TABLE friends(
fid int PRIMARY KEY auto_increment,
fname VARCHAR(20) not null,
pid int not null,
FOREIGN KEY(pid) REFERENCES person(pid)
);
insert into person values
(null,'张三',default,20,'李四,王五,赵六','河南省','郑州市');
-- 查询测试
select * from person;
-- 插入测试数据
INSERT INTO friends VALUES(null,'李四',1);
INSERT INTO friends VALUES(null,'王五',1);
INSERT INTO friends VALUES(null,'赵六',1);
-- 查询测试
select * from friends;
/*
联表查询
        select 字段 from 表1,表2 where 连接条件
    内连接:
        select 字段 from 表1 inner join 表2 on 连接条件
    外连接:
        select 字段 from 表1 left join 表2 on 连接条件
        select 字段 from 表1 right join 表2 on 连接条件
*/ 
SELECT * FROM parson,friends WHERE person.pid=friends.pid;
SELECT * FROM parson p,friends f WHERE p.pid=f.pid;

/*

拥有朋友(字段)
*/

-- 创建数据库
drop database if exists mydb;
create database mydb character set utf8;
use mydb;

-- 创建Person表
/*
# 不符合第一范式
# 家乡字段:不符合第一范式(列不可再分,列的原子性)
# 可以把“河南省郑州市”分为两个字段“河南省”“郑州市”

create table person(
pid int primary key auto_increment, -- 编号
pname varchar(20) not null, -- 姓名
psex char(2) default "男", -- 性别
page int not null, -- 年龄
pfriends varchar(100), -- 朋友
phome varchar(100) -- 家乡
);
insert into person values
(null,'张三',default,20,'李四,王五,赵六','河南省郑州市');
*/
-- 一个人,多个朋友,属于一个字段带多个数据
-- 再设计一个表作为朋友表(通过外键来设计关系)
create table person(
pid int primary key auto_increment, -- 编号
pname varchar(20) not null, -- 姓名
psex char(2) default "男", -- 性别
page int not null, -- 年龄
pfriends varchar(100), -- 朋友
sheng varchar(50), -- 省
shi varchar(50) -- 市
);
-- 朋友表
CREATE TABLE friends(
fid int PRIMARY KEY auto_increment,
fname VARCHAR(20) not null,
pid int not null,
FOREIGN KEY(pid) REFERENCES person(pid)
);
insert into person values
(null,'张三',default,20,'李四,王五,赵六','河南省','郑州市');
-- 查询测试
select * from person;
-- 插入测试数据
INSERT INTO friends VALUES(null,'李四',1);
INSERT INTO friends VALUES(null,'王五',1);
INSERT INTO friends VALUES(null,'赵六',1);
-- 查询测试
select * from friends;
/*
联表查询
        select 字段 from 表1,表2 where 连接条件
    内连接:
        select 字段 from 表1 inner join 表2 on 连接条件
    外连接:
        select 字段 from 表1 left join 表2 on 连接条件
        select 字段 from 表1 right join 表2 on 连接条件
*/ 
SELECT * FROM person,friends WHERE person.pid=friends.pid;
SELECT * FROM person p,friends f WHERE p.pid=f.pid;
SELECT * FROM person p left JOIN friends f on p.pid=f.pid;
SELECT * FROM person p inner JOIN friends f on p.pid=f.pid;
SELECT * FROM person p RIGHT JOIN friends f on p.pid=f.pid;
SELECT pname,fname FROM person p,friends f WHERE p.pid=f.pid;
SELECT CONCAT(pname,"的朋友有",fname) from person p inner JOIN friends f on p.pid=f.pid;

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值