ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 求助:使用SQL找出所有表一序号在表二中数据,合并在一起

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-2 19:19 | 显示全部楼层
ivccav 发表于 2018-6-2 00:32
上传附件时提示:Upload Error: 502。

你把代码复制到你的文件即可。

excute(strsql,,1)这一句提示缺少参数?

TA的精华主题

TA的得分主题

发表于 2018-6-2 19:34 | 显示全部楼层
ztccsj 发表于 2018-6-2 19:19
excute(strsql,,1)这一句提示缺少参数?

excute(strsql,,1)缺少参数?绝对没有可能性。只有第一个参数是必须的。
你写错了吧。excute是execute.

我重新下载了你的附件,并用我的代码测试,完全没有任何问题。查询也就几秒钟。

QQ图片20180602193000.png

SQL找出所有表一序号在表二中数据,合并在一起.zip (1.45 MB, 下载次数: 3)


评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-2 23:16 | 显示全部楼层
ivccav 发表于 2018-6-2 19:34
excute(strsql,,1)缺少参数?绝对没有可能性。只有第一个参数是必须的。
你写错了吧。excute是execute.
...

你好,还是不正确,表二中的内容,取出来后都重复了(翻倍了)

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-2 23:18 | 显示全部楼层
ivccav 发表于 2018-6-2 19:34
excute(strsql,,1)缺少参数?绝对没有可能性。只有第一个参数是必须的。
你写错了吧。excute是execute.
...

你好,表2中的数据,取出来后,都重复了,请看看再怎么修改,我就是想要这种简洁的sql语句,但是我弄了很久,不是这个多就是那个少的

TA的精华主题

TA的得分主题

发表于 2018-6-2 23:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
ztccsj 发表于 2018-6-2 23:16
你好,还是不正确,表二中的内容,取出来后都重复了(翻倍了)



我不清楚你的sheet1和sheet2两个表的关系。我以为sheet1和sheet2是不同的。

你可以根据需要把Union All改为Union:

Union:对两个结果集进行并集操作,不包括重复行(如果整行相同时,只保留一行);

Union All:对两个结果集进行并集操作,包括重复行(简单合并,不做重复行判断);

TA的精华主题

TA的得分主题

发表于 2018-6-3 11:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
使用Excel做表连接查询如果字段(列)左侧有空单元格,很可能会发生右侧数据左移,因此必须反复测试结果的正确性.

TA的精华主题

TA的得分主题

发表于 2018-6-3 11:59 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-6-3 14:06 | 显示全部楼层
本帖最后由 amazeyeli 于 2018-6-3 14:09 编辑

从表2中取出与表1中ID号相同的记录

select * from tb2 where id in (select id from tb1);

select b.* from tb2 as b inner join tb1 as a on a.id=b.id;

select * from tb2 where exists (select * from tb1 as a where id=a.id);

如果表1和表1结构相同或相似,两表可以合并
select * from tb1
union
select * from tb2 where exists (select * from tb1 as a where id=a.id)

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-6-5 16:33 | 显示全部楼层
amazeyeli 发表于 2018-6-3 14:06
从表2中取出与表1中ID号相同的记录

select * from tb2 where id in (select id from tb1);

in 可以这样用是吗,我回头测试。感谢

TA的精华主题

TA的得分主题

发表于 2018-6-5 17:53 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
ztccsj 发表于 2018-6-5 16:33
in 可以这样用是吗,我回头测试。感谢

in和or是一样的效果,in比join效率低很多倍。

in只适合几个值的时候用,你这几百个值,join是唯一的选择
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-22 07:14 , Processed in 0.043579 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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