ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1959|回复: 1

access中合并两张表为一张表\联合查询\union

[复制链接]

TA的精华主题

TA的得分主题

发表于 2013-6-19 16:18 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
已知表A结构
=================================
ID       product    price    provider
=================================

表B结构
=================================
ID       product    color
=================================

表A中的存在的数据 表B中可能没有,例如表A中可能有记录
=================================
ID       product    price    provider
1        sock          23       smartShop
=================================

但表B中却没有ID=1 product=sock的记录;
同样表B中存在的数据表A中也可能没有,例如表B中可能有记录
=================================
ID       product    color
2        dress        red
=================================
但表A中却找不到ID=2 product=dress的记录;
对于上边两种情况,要求表合并后的结果如下:
=================================
ID       product       price       provider             color
1        sock            23            smartShop      
2        dress                                                 red
==================================
如果表A中存在的数据,表B中也存在则直接合并,例如:
表A:
=================================
ID       product    price    provider
3        T-shirt         12       Mall
=================================

表B:
=================================
ID       product    color
3       T-shirt        white
=================================
合并后为:
=================================
ID       product       price       provider       color
3        T-shirt          12         Mall              white
==================================
最后要求合并后的表无重复记录。

思路:考虑到合并表,首先肯定要用UNION关键字,UNION的作用是将两个结构相同的表进行合并,
所以我们接下来考虑要构造这两个结构相同的表。连接表肯定需要JOIN语句,又根据要求知道表A和表B分别含有
彼此没有的记录,所以使用表A与表B分别进行左,友连接;或者用表A与表B进行左连接,再用表B与表A进行左连接;
然后用连接后得到的两个表进行UNION即可得到我们最终想要的结果集。

最终的SQL语句如下:
select A.ID as ID, A.product as Product, price, provider, color from A left join B on A.ID=B.ID
UNION
select B.ID as ID,B.product as Product, price, provider, color from A right join B on A.ID=B.ID





评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2013-6-19 16:44 | 显示全部楼层
相当于acc缺少的:full join
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-29 12:37 , Processed in 0.017862 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表