【SQL】多个表的查询
1.元组变量
SELECT * FROM a AS x, a AS y;
结果是显示自己和自己的笛卡尔乘积。
如果查询中对于某一个关系使用了多次,为了区别他们的属性,需要对关系定义别名,然后用 别名.属性 来区分。
SELECT Star1.name, Star2.name
FROM MovieStar Star1, MovieStar Star2
WHERE Star1.address = Star2.address
AND Star1.name < Star2.name;
注意,最后名称要用<, 如果只用 <> 会导致同样的两个名字输出两遍(仅顺序不同)
2.消除属性歧义
如果几个关系都有相同的属性名,通过 关系名.属性名 解决。
SELECT MovieStar.name, MovieExec.name
FROM MovieStar, MovieExec
WHERE MovieStar.address = MovieExec.address;
3.
Mysql 中不支持 SQL 的 INTERSECT(交集), EXCEPT(差),UNION(并集)关键字
4.子查询
某个查询是另一个查询的一部分时,称为子查询。
4.1 产生标量值的子查询(子查询的结果仅有一个唯一值)
SELECT name
FROM MovieExec
WHERE cert# =
(SELECT producerC#
FROM Movies
WHERE title = 'Star Wars');
上面语句成功的必要条件:子查询中返回的producerC#只能有一个成员!多了会报错!!
如图,是一个返回了多个值的例子。报错Subquery returns more than 1 row.
4.2关系的条件表达式
下面的表达式,必须在关系是子查询的时候使用,返回布尔值结果。
EXISTS R: R非空为真
s IN R: s等于R中的某个值
s NOT IN R: s不等于R中任何一个值
s > ALL R: s比一元R中的任意值都大(R未必一元,只要s与R的分量相同即可)
s > ANY R: s至少大于一元R中的某一个值
NOT 可以加在前面表示取反: NOT EXISTS R; NOT s > ANY R;
上述例子中的 > 可以换成 =, <>, <, >=, <= 中的任何一个。
SELECT name
FROM MovieExec
WHERE cert# IN
(SELECT producerC#
FROM Movies
WHERE (title, year) IN
(SELECT movieTitle, movieYear
FROM StarsIn
WHERE starName = 'Harrison Ford'
)
);
4.3 关联子查询
SELECT title
FROM Movies Old
WHERE year < ANY
(SELECT year
FROM Movies
WHERE title = Old.title
);
找到被多部电影同时使用的电影名,一个电影名出现n次则输出n-1次。
与上面的不同在于:Old.title的值不是固定的
4.4 FROM子句中的子查询
SELECT name
FROM MovieExec, (SELECT producerC#
FROM Movies, StarsIn
WHERE title = movieTitle AND
year = movieYear AND
starName = 'Harrison Ford'
)Prod
WHERE cert# = Prod.producerC#;
4.5连接表达式-交叉连接
SELECT * FROM Movies CROSS JOIN StarsIn;
CROSS JOIN: 表示交叉连接,即积或笛卡尔积。
4.6连接表达式-θ连接
θ连接: 在笛卡尔积的基础上做条件选择。
JOIN ... ON: ON后面跟条件
Movies JOIN StarsIn ON
title = movieTitle AND year = movieYear;
SELECT title, year, length, genre
FROM Movies JOIN StarsIn ON
title = movieTitle AND year = movieYear;
4.7连接表达式-自然连接
自然连接:把两个关系中相同属性的值相同的取出。如
相同的属性不会多次出现,这是自然连接和笛卡尔积的关键区别
NATURAL JOIN:
SELECT *
FROM Nums1 NATURAL JOIN Nums2;
4.8连接表达式-外连接
外连接:把自然连接中的的悬浮元祖考虑进来,把没有值的地方用空显示。
关系U | 关系V | 左外连接结果 | 右外连接结果 | 全外连接结果 |
左外连接:MovieStar NATURAL LEFT OUTER JOIN MovieExec;
右外连接:MovieStar NATURAL RIGHT OUTER JOIN MovieExec;
全外连接:MovieStar NATURAL FULL OUTER JOIN MovieExec; (mysql不支持全外连接,但是左右外连接支持)
书上说,外连接也可以加条件,方法是把NATURAL去掉后在JOIN后面通过ON关键字加条件。但是我在mysql上实验了下,发现不行。去掉NATURAL后得到的结果就不是自然连接了,相同的属性名会出现多次,跟笛卡尔积比较像。
【SQL】多个表的查询的更多相关文章
- SQL的多表连接查询
SQL的多表连接查询 多表连接查询具有两种规范,SQL92和SQL99规范. SQL92规范支持下列多表连接查询: (1)等值连接: (2)非等值连接: (3)外连接: (4)广义笛卡尔积: SQL9 ...
- SQL Server 锁表、查询被锁表、解锁相关语句
SQL Server 锁表.查询被锁表.解锁相关语句,供参考. --锁表(其它事务不能读.更新.删除) BEGIN TRAN SELECT * FROM <表名> WITH(TABLOCK ...
- SQL Server多表同时查询
今天在练sql server发现多条语句同时使用可以多表同时查询,具体操作如下: 代码示例: USE teachingGOSELECT *FROM dbo.teach_classORDER BY cl ...
- MySQL常用sql语句-----数据表的查询操作
常用的sql语句如下,应对工作足以 1.查询指定字段 select c_id,c_age,c_name from t_student; select c_id as 编号,c_name as 姓名,c ...
- sql server锁表、查询被锁表、解锁被锁表的相关语句
MSSQL(SQL Server)在我的印象中很容易锁表,大致原因就是你在一个窗口中执行的DML语句没有提交,然后又打开了一个窗口对相同的表进行CRUD操作,这样就会导致锁表.锁表是一种保持数据一致性 ...
- SQL语句多表连接查询语法
一.外连接 1.左连接 left join 或 left outer join SQL语句:select * from student left join score on student.Num= ...
- SQL server多表联合查询
参考网址: https://blog.csdn.net/zou15093087438/article/details/79226394 1. 外连接可分为:左连接.右连接.完全外连接. a. 左连接 ...
- 【SQL】单个表的查询
看到一本好书:名字叫做<数据库系统基础教程> 第三版 岳丽华等译 讲得很清楚,也不啰嗦. 这里是书中第六章的部分笔记: 一.常见用法: 1. AS 定义别名 可省略 2. 可以用加减乘除 ...
- sql语句 两表关联查询计算数量
select sum(a1.`num`) from `order_orderlistrow` as a1 INNER JOIN `order_orderlist` as a2 on a1.`ord ...
- SQL多表连接查询(详细实例)
转载博客:joeleo博客(http://www.xker.com/page/e2012/0708/117368.html) 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:stud ...
随机推荐
- phpcms v9手机门户配置方法
一.确定一个域名作为你手机wap站点的访问域名,例如:http://m.tezhengzong.com. 接下来在域名管理系统中简析这个域名到你的服务器地址. 二.修改\caches\configs\ ...
- windows下 eclipse搭建spark java编译环境
环境: win10 jdk1.8 之前有在虚拟机或者集群上安装spark安装包的,解压到你想要放spark的本地目录下,比如我的目录就是D:\Hadoop\spark-1.6.0-bin-hadoop ...
- 基于SDN的IP RAN网络虚拟化技术
http://www.zte.com.cn/cndata/magazine/zte_technologies/2014/2014_4/magazine/201404/t20140421_422858. ...
- MD5消息摘要算法
Message Digest 5(消息摘要算法)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护. MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩" ...
- could not read column value from result set:
错误描述: INFO [http-apr-8080-exec-26] (NullableType.java:203) - could not read column value from result ...
- [剑指Offer] 25.复杂链表的复制
/* struct RandomListNode { int label; struct RandomListNode *next, *random; RandomListNode(int x) : ...
- Delphi中取得程序版本号
Delphi做的程序,如果想包含版本信息, 必须在Delphi的集成编辑环境的菜单“Project/Options/Version Info”里面添加版本信息.即在Version Info 选项卡中选 ...
- P2161 [SHOI2009]会场预约
题目描述 PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也就是说,前一个 ...
- THUSC2014酱油记
Day0: 坐飞机到北京,然后报到...跟jason_yu分到一个房间,刚好可以蹭点RP.发现房间460RMB/晚,但再带一份早餐就500RMB,难道早餐是40RMB么...在一家川菜馆吃的午晚餐,感 ...
- 遇到问题---java---myeclipse中maven项目引用另一个导致的resource文件混乱的问题
遇到情况 情况是这样的,我们在构建项目时,经常会把一些公用的类和配置提取出去,作为一个公共项目.然后把公共项目作为一个jar包构件引入我们当前的项目中. 引入方式是 <dependency> ...