内容简介:多表查询中,如果没有连接条件,则会产生笛卡尔积数学中的定义:假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1),(b,2)}
多表查询:
select listname from tablename1,tablename2;
笛卡尔积
多表查询中,如果没有连接条件,则会产生笛卡尔积
数学中的定义:假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为
{(a,0),(a,1),(a,2),(b,0),(b,1),(b,2)}
实际运行环境下,应避免使用笛卡尔积;
解决方案:
在where加入有效的连接条件-----> 等值连接(连接n张表,需要n-1个连接条件)
select * from employee,department where employee.deptno = department.deptno
主键约束
约束当前表中,指定列的值非空且唯一
外键约束
表A中的外键列的值必须参照表B中的某一列的值
MySQL中, InnoDB支持外键和事务,MyISAM不支持外键和事务
/* 修改表的存储引擎 */ alter table [tablename] engine='InnoDB'; alter table [tablename] engine='MyISAM';
添加外键后:
一般情况下,如果列要使用外键列,可以这样命名: 引用表名_引用列名
我们要引用productdir表中的id列
在开发中,为了提高性能,会故意删除外键约束,通过代码来控制数据的合理性。
隐式连接
隐式內连接(看不到连接):仅选出两张表中互相匹配的记录
隐式连接缺点:
- 需要在where条件中加入连接条件,如果忘了写,代码不会报错,但是会产生笛卡尔积
- 只能做内连接
显示连接
内连接查询:查询效果和隐式内连接相同
select [table.list],[table.list] from [table] join [table] on(连接关系); select e.empno,e.name,d.dname from emp e join dept d on(e.deptno = d.deptno); /* 连接关系列名相同可以用using */ select e.empno,e.name,d.dname from emp e join dept d using(deptno);
外连接:
- 左连接:将join左边表全部数据都查询处理啊,join右边表不匹配的数据NULL填充
/* 将左边表所有数据都显示 */ select * from emp left join dept using(deptno);
- 右连接
- 全外连接:MySQL暂时不支持
自连接:把一张表看成两张表来做查询
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spring实战(第4版)
Craig Walls 沃尔斯 / 张卫滨 / 人民邮电出版社 / 2016-4-1 / CNY 89.00
《Spring实战(第4版)》是经典的、畅销的Spring学习和实践指南。 第4版针对Spring 4进行了全面更新。全书分为四部分。第1部分介绍Spring框架的核心知识。第二部分在此基础上介绍了如何使用Spring构建Web应用程序。第三部分告别前端,介绍了如何在应用程序的后端使用Spring。第四部分描述了如何使用Spring与其他的应用和服务进行集成。 《Spring实战(第4......一起来看看 《Spring实战(第4版)》 这本书的介绍吧!
XML 在线格式化
在线 XML 格式化压缩工具
RGB CMYK 转换工具
RGB CMYK 互转工具