求句多表组合查询的sql

shadowno 2008-10-22 12:36:40
有4个表,如出库单表,bill, 第一种商品表t1,第二中商品表t2,第三种商品表t3

这4个表以单号作为关联,4个表中都含有单号字段,怎样把出库单中单号相等的记录查询出来。

我用 
select × from bill,t1,t2,t3
where bill.billno=t1.billno and bill.billno=t2.billno and bill.billno=t3.billno
查出大量重复记录

怎样在同一行上匹配4个表中的数据啊
...全文
47 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
fcuandy 2008-10-22
  • 打赏
  • 举报
回复
意思很明确,说明billno中与其它几个表都是一对多或多对多。

bill
1
2
3

t1
1
2
1
2
3

t2
1
1
1

当然会有很多重复行了。 因为t1与t2(这里我就不说t3了,多个表本质不变)中单号为1的,你自己都不知道应该让他们怎么组合。

还是基本的二维概念的问题。
shadowno 2008-10-22
  • 打赏
  • 举报
回复
两个表 直接select * from bill,t1 where bill.billno=t1.billno 没问题,4个表就出现重复记录了,好像其他几个表间t1,t2,t3 也进行匹配了,所以出现了太多的类似重复行
shadowno 2008-10-22
  • 打赏
  • 举报
回复
直接?
select × from bill,t1,t2,t3
where bill.billno=t1.billno and bill.billno=t2.billno and bill.billno=t3.billno

有太多重复的行,因为billno,在每个表中都不是唯一的,一个单上可能出t1,t2,t3中的商品好几样
-狙击手- 2008-10-22
  • 打赏
  • 举报
回复
这4个表以单号作为关联,4个表中都含有单号字段,怎样把出库单中单号相等的记录查询出来。

--
你的是单号,直接bill表就可以的呀
tianhuo_soft 2008-10-22
  • 打赏
  • 举报
回复
UP
本课程根据讲师十多年在世界500强外企的生产环境中的SQL Serer数据库管理和项目实施经验倾心打造。课程系统性强,知识体系完整,覆盖90%以上的企业环境下SQL Server高可用场景,课程中不仅演示详细的操作步骤,更加突出最常见的故障和问题,让学员少走“弯路”,不只是让学员学会“操作”更能让学员“操作”的规范,满满的干货分享,一些课程资料(架构图、部署规划表格等)不仅可以帮助学员掌握技能,也可以作为学员在企业生产环境中实施SQL Server高可用的配置文档、操作手册等。课程的实验环境介绍:1)全部基于微软域环境和企业版SQL Server AOAG - 95%以上的企业环境都是在域环境中,不介绍非域环境和标准版的SQL Server高可用性组,这的配置在企业中较罕见,没有实践意义,不浪费学员时间。2)相应域环境已提前部署和配置好 - 学员导入虚拟机即可开始实验,无需从零开始搭建域环境,所有实验中SQL Server均已加域,直入主题,节省大量时间。3)最新的Windows Server故障转移集群(WS2016、WS2019)和最新版本的SQL Server(SQL2017、SQL2019) -  WS2016-SQL2017与WS2019-SQL2019是目前大多数企业SQL Server高可用的主要平台,基于微软产品生命周期现在一些企业也在讲早期的AOAG向这两个版本迁移,掌握这两种组合不仅让学员学会,更能学有所用。本课程为后续SQL Server进阶课程铺垫,是通向SQL Server DBA 专家的必经之路,讲师每周答疑两次。所有课程资料包括:课程PPT、架构图、部署规划表格、各类脚本学员均可下载。     

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧