MySQL数据库之多表操作

首先说一下什么是外键,外键是指引用另外一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束。使用外键的好处就是保证数据的完整性。比如说有一个班级表和一个学生表,当删除一个班级的时候,学生表中班级的id就相当于是垃圾数据或者错误数据。所以学生表使用外键关联到班级表,当删除班级的时候,只有学生表中没有使用该班级的id(也就是没有该班级的学生时)才可以删除班级,若有学生的话,必须先删除学生,或者把学生表中班级的id值空。才可以删除。如何为表添加外键呢:alter table 表名add constraint FK_ID foreign key (外键字段名) references 外表表名 (主键字段名);

如:alter table student add constraint FK_IDforeign key (class_id) references class (id);

删除外键的语句:alter table 表名drop foreign key 外键名;

如:alter table student drop foreign key FK_ID;

当学生表中引用班级表的id,就说明班级是主表,学生是从表。因为外键列只能插入参照列存在的值,所以如果要为两个表添加数据,就先为主表添加数据。

       多表操作的重点是连接查询和子查询。分别是:交叉连接—select * from 表1 cross join 表2;这种方法一般很少用。

下面说一下内连接—select 查询字段 from 表1 [inner] join表2 on 表1.关系字段 =表2.关系字段;

如:select employee.name, department.dname fromdepartment join employee on department.did=employee.did;

首先判断员工表的id是否等于部门表的id,也就是查各部门的员工。这句相当于:select employee.name, department.dname from department,employee where department.did=employee.did;

       外链接分为左连接、左外链接、右连接、右外链接,语法格式为:

Select 所有字段 from 表1 left|right [outer] join 表2 on 表1.关系字段=表2.关系字段 where 条件;

左连接:返回包括左表中的所以记录和有表中符合连接条件的记录。

右连接:返回包括右表中的所以记录和有表中符合连接条件的记录。

如:select department.did, department.dname, employee.namefrom department left join employee on department.did=employee.did;

id

dname

name

1

网络部

王红

1

网络部

李强

2

媒体部

赵四

3

研发部

null

5

人事部

Null

而右连接是这样的:如:

select department.did,department.dname, employee.name from department right join employee ondepartment.did=employee.did;

id

dname

Name

1

网络部

王红

1

网络部

李强

2

媒体部

赵四

Null

null

何娟

最后看一下子查询:子查询是嵌套在另一个语句内部的查询,可以嵌套在select、insert…into等中,在执行查询语句时,首先执行子查询,然后将返回结果作为外层语句的过滤条件。子查询包括IN、EXISTS、ANY、ALL。

下面直接上语句:select * from department where did [NOT] IN(select did from employee where age=20);查询存在员工年龄等于20 的部门;关键字exists只返回true或false,

select * fromdepartment where did exists(select did from employee where age>20);如果有年龄大于20的,就查询所有部门。ANY关键字表示满足其中任意一个条件便可。他们可以返回一个值列表,然后给外层查询进行比较,如:select * from department where did>any(selectdid from employee);查询员工表中的所以id,并返回一个id列表,供department 中的did比较,只要满足就返回。ALL关键字与ANY关键字类似,他要满足子查询的所有条件。select * from department where did>all(select didfrom employee);再看一条语句,select * from department where did=(selectdid from employee where name=’赵四’).

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值