postgresql表之间连接
上传者:姜琦|上传时间:2015-04-29|密次下载
postgresql表之间连接
查询可以一次访问多个表,或者用某种方式访问一个表,而同时处理该表的多个行。 一个同时访问同一个或者不同表的多个行的查询叫连接(join)查询。 举例来说,比如你想列出所有天气记录以及这些记录相关的城市。 要实现这个目标,我们需要拿 weather表每行的city 字段和cities表所有行的name字段进行比较, 并选取那些这些数值相匹配的行。
注意: 这里只是一个概念上的模型。该连接通常以比实际比较每个可能的行配对更高效的方式执行, 但这些是用户看不到的。
这个任务可以用下面的查询来实现:
SELECT *
FROM weather, cities
WHERE city = name;
city | temp_lo | temp_hi | prcp | date | name | location ---------------+---------+---------+------+------------+---------------+----------- San Francisco | 46 | 50 | 0.25 | 1994-11-27 | San Francisco | (-194,53)
San Francisco | 43 | 57 | 0 | 1994-11-29 | San Francisco | (-194,53)
(2 rows)
观察结果集的两个方面:
?
? 没有城市Hayward的结果行。这是因为在 cities 表里面没有 Hayward的匹配行,所以连接忽略 weather表里的不匹配行。我们稍后将看到如何修补这个毛病。 有两个字段包含城市名字。这是正确的, 因为 weather 和 cities 表的字段是接在一起的。
不过,实际上我们不想要这些, 因此你将可能希望明确列出输出字段而不是使用 *:
SELECT city, temp_lo, temp_hi, prcp, date, location
? FROM weather, cities
WHERE city = name; ?
练习:. 看看省略 WHERE 子句的语义是什么。
因为这些字段的名字都不一样,所以分析器自动找出它们属于哪个表, 但是在连接查询里使用字段全称是很好的风格:
SELECT weather.city, weather.temp_lo, weather.temp_hi,
weather.prcp, weather.date, cities.location
FROM weather, cities
WHERE http://wendang.chazidian.com = weather.city;
到目前为止,这种类型的连接查询也可以用下面这样的形式写出来:
SELECT *
FROM weather INNER JOIN cities ON (weather.city = http://wendang.chazidian.com); 这个语法并非象上面那个那么常用,我们在这里写出来是为了让你更容易了解后面的主题。
现在我们将看看如何能把Hayward记录找回来。 我们想让查询干的事是扫描 weather 表, 并且对每一行都找出匹配的 cities 表里面的行。 如果我们没有找到匹配的行,那么我们需要一些"空值"代替cities表的字段。 这种类型的查询叫外连接。 (我们在此之前看到的连接都是内部连接。)这样的命令看起来象这样:
SELECT *
FROM weather LEFT OUTER JOIN cities ON (weather.city =
http://wendang.chazidian.com);
city | temp_lo | temp_hi | prcp | date | name | location
---------------+---------+---------+------+------------+---------------+-----------
Hayward | 37 | 54 | | 1994-11-29 | |
San Francisco | 46 | 50 | 0.25 | 1994-11-27 | San Francisco | (-194,53)
San Francisco | 43 | 57 | 0 | 1994-11-29 | San Francisco | (-194,53)
(3 rows) 这个查询是一个左手边外连接, 因为在连接操作符(译注∶LEFT OUTER JOIN)左手边的表中的行在输出中至少要出现一次, 而在右手边的行将只输出那些与左手边行有对应匹配的行。 如果输出的左手边表的行没有对应匹配的右手边表的行,那么在右手边行的字段将填充空(NULL)。
练习:. 还有右连接和全连接。试着找出来它们能干什么。
我们也可以把一个表和自己连接起来。这叫做自连接。 比如,假设我们想找出那些在其它天气记录的温度范围之外的天气记录。 这样我们就需要拿 weather 表里每行的 temp_lo 和 temp_hi 字段
与 weather 表里其它行的 temp_lo 和 temp_hi 字段进行比较。我们可以用下面的查询实现这个目标:
SELECT W1.city, W1.temp_lo AS low, W1.temp_hi AS high,
W2.city, W2.temp_lo AS low, W2.temp_hi AS high
FROM weather W1, weather W2
WHERE W1.temp_lo < W2.temp_lo
AND W1.temp_hi > W2.temp_hi;
city | low | high | city | low | high
---------------+-----+------+---------------+-----+------
San Francisco | 43 | 57 | San Francisco | 46 | 50
Hayward | 37 | 54 | San Francisco | 46 | 50
(2 rows) 在这里我们把weather表重新标记为 W1 和 W2 以区分连接的左手边和右手边。 你还可以用这样的别名在其它查询里节约一些敲键,比如:
SELECT *
FROM weather w, cities c
WHERE w.city = c.name;
你以后会经常碰到这样的缩写的.
下载文档
热门试卷
- 2016年四川省内江市中考化学试卷
- 广西钦州市高新区2017届高三11月月考政治试卷
- 浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
- 浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
- 辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
- 广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
- 广西钦州市钦州港区2017届高三11月月考政治试卷
- 广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
- 广西钦州市高新区2016-2017学年高二11月月考政治试卷
- 广西钦州市高新区2016-2017学年高一11月月考政治试卷
- 山东省滨州市三校2017届第一学期阶段测试初三英语试题
- 四川省成都七中2017届高三一诊模拟考试文科综合试卷
- 2017届普通高等学校招生全国统一考试模拟试题(附答案)
- 重庆市永川中学高2017级上期12月月考语文试题
- 江西宜春三中2017届高三第一学期第二次月考文科综合试题
- 内蒙古赤峰二中2017届高三上学期第三次月考英语试题
- 2017年六年级(上)数学期末考试卷
- 2017人教版小学英语三年级上期末笔试题
- 江苏省常州西藏民族中学2016-2017学年九年级思想品德第一学期第二次阶段测试试卷
- 重庆市九龙坡区七校2016-2017学年上期八年级素质测查(二)语文学科试题卷
- 江苏省无锡市钱桥中学2016年12月八年级语文阶段性测试卷
- 江苏省无锡市钱桥中学2016-2017学年七年级英语12月阶段检测试卷
- 山东省邹城市第八中学2016-2017学年八年级12月物理第4章试题(无答案)
- 【人教版】河北省2015-2016学年度九年级上期末语文试题卷(附答案)
- 四川省简阳市阳安中学2016年12月高二月考英语试卷
- 四川省成都龙泉中学高三上学期2016年12月月考试题文科综合能力测试
- 安徽省滁州中学2016—2017学年度第一学期12月月考高三英语试卷
- 山东省武城县第二中学2016.12高一年级上学期第二次月考历史试题(必修一第四、五单元)
- 福建省四地六校联考2016-2017学年上学期第三次月考高三化学试卷
- 甘肃省武威第二十三中学2016—2017学年度八年级第一学期12月月考生物试卷
网友关注
- 2018重庆公务员行测每日一练判断推理练习题答案12.12
- 2017下半年重庆市考行测试卷亮点解读
- 2018重庆公务员考试面试热点模拟题:劝阻吸烟引发老人离世
- 2016下半年重庆公务员考试申论亮点:提出对策题“重卷而来”
- 2016重庆公务员面试模拟题:保护好祖国花朵
- 2017下半年重庆公务员考试申论每周一练答案:军装热现象
- 2017下半年重庆公务员考试申论主题切入知识产权保护
- 2017下半年重庆公务员考试行测演练厅之生活常识模拟题
- 2018重庆公务员行测每日一练言语理解练习题12.13
- 2018重庆公务员考试面试题库:面试每日一练结构化面试模拟题1.5
- 2017下半年重庆公务员考试申论每周一练:品牌建设
- 2017重庆市公务员考试申论试题答题要点
- 2017下半年重庆市考行测真题深度解读
- 2017下半年重庆公务员考试行测真题及答案解析
- 2016下半年重庆公务员考试申论真题
- 2017年重庆市公务员考试行测试题答案及解析
- 2016年重庆公务员面试真题(6月19日)
- 2018重庆公务员面试中情景模拟题:巧用生活智慧
- 2018重庆公务员面试模拟题:有人质疑选票造假如何处理
- 2018重庆公务员面试模拟题:“打伞哥”火爆朋友圈
- 2017下半年重庆公务员考试申论每周一练:军装热现象
- 2018重庆公务员考试行测题库:行测每日一练数量关系练习题答案12.18
- 2018重庆公务员面试模拟题:如何看待“随手拍”
- 2016下半年重庆公务员考试行测真题个性化盘点
- 2018重庆公务员行测每日一练判断推理练习题12.14
- 重庆市考申论每周一练:PPP模式(政府和社会资本合作共建基础设施)
- 2017下半年重庆市考行测特色题目盘点
- 2016重庆公务员面试模拟题:“狗占人座”
- 2016年重庆公务员地税系统面试(6月18日)
- 2017下半年重庆公务员考试申论真题
网友关注视频
- 二年级下册数学第三课 搭一搭⚖⚖
- 沪教版八年级下册数学练习册21.3(2)分式方程P15
- 外研版英语七年级下册module3 unit2第二课时
- 冀教版小学数学二年级下册第二周第2课时《我们的测量》宝丰街小学庞志荣.mp4
- 19 爱护鸟类_第一课时(二等奖)(桂美版二年级下册)_T502436
- 第4章 幂函数、指数函数和对数函数(下)_六 指数方程和对数方程_4.7 简单的指数方程_第一课时(沪教版高一下册)_T1566237
- 【部编】人教版语文七年级下册《过松源晨炊漆公店(其五)》优质课教学视频+PPT课件+教案,辽宁省
- 七年级英语下册 上海牛津版 Unit3
- 外研版英语七年级下册module3 unit1第二课时
- 第五单元 民族艺术的瑰宝_15. 多姿多彩的民族服饰_第二课时(市一等奖)(岭南版六年级上册)_T129830
- 人教版历史八年级下册第一课《中华人民共和国成立》
- 30.3 由不共线三点的坐标确定二次函数_第一课时(市一等奖)(冀教版九年级下册)_T144342
- 化学九年级下册全册同步 人教版 第25集 生活中常见的盐(二)
- 《空中课堂》二年级下册 数学第一单元第1课时
- 人教版二年级下册数学
- 【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,辽宁省
- 每天日常投篮练习第一天森哥打卡上脚 Nike PG 2 如何调整运球跳投手感?
- 苏科版数学八年级下册9.2《中心对称和中心对称图形》
- 【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
- 【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,湖北省
- 小学英语单词
- 外研版英语三起5年级下册(14版)Module3 Unit2
- 沪教版八年级下册数学练习册一次函数复习题B组(P11)
- 精品·同步课程 历史 八年级 上册 第15集 近代科学技术与思想文化
- 【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,天津市
- 北师大版小学数学四年级下册第15课小数乘小数一
- 沪教版八年级下册数学练习册21.3(3)分式方程P17
- 19 爱护鸟类_第一课时(二等奖)(桂美版二年级下册)_T3763925
- 冀教版小学英语五年级下册lesson2教学视频(2)
- 七年级下册外研版英语M8U2reading
精品推荐
- 2016-2017学年高一语文人教版必修一+模块学业水平检测试题(含答案)
- 广西钦州市高新区2017届高三11月月考政治试卷
- 浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
- 浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
- 辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
- 广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
- 广西钦州市钦州港区2017届高三11月月考政治试卷
- 广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
- 广西钦州市高新区2016-2017学年高二11月月考政治试卷
- 广西钦州市高新区2016-2017学年高一11月月考政治试卷
分类导航
- 互联网
- 电脑基础知识
- 计算机软件及应用
- 计算机硬件及网络
- 计算机应用/办公自动化
- .NET
- 数据结构与算法
- Java
- SEO
- C/C++资料
- linux/Unix相关
- 手机开发
- UML理论/建模
- 并行计算/云计算
- 嵌入式开发
- windows相关
- 软件工程
- 管理信息系统
- 开发文档
- 图形图像
- 网络与通信
- 网络信息安全
- 电子支付
- Labview
- matlab
- 网络资源
- Python
- Delphi/Perl
- 评测
- Flash/Flex
- CSS/Script
- 计算机原理
- PHP资料
- 数据挖掘与模式识别
- Web服务
- 数据库
- Visual Basic
- 电子商务
- 服务器
- 搜索引擎优化
- 存储
- 架构
- 行业软件
- 人工智能
- 计算机辅助设计
- 多媒体
- 软件测试
- 计算机硬件与维护
- 网站策划/UE
- 网页设计/UI
- 网吧管理