13

直到今天,我对内部连接的想法是它将返回满足连接条件的表中存在的最小行数。

前任。如果表 A包含 4 行,表 B包含 7 行。如果满足加入条件,我期望 4 行可以是最大输出。

我刚刚写了一个 sp,我在其中创建了两个临时表并填充它们。然后我对它们进行了内部连接,但返回了更多行(在我的情况下,返回了 29 行,我期待 4 行)经过一番搜索,我找到了这个 链接

这证实了我可以发生,但我仍然想知道我有什么选择来限制返回的结果。

下面是我的存储过程。

ALTER PROCEDURE [dbo].[GetDDFDetailOnSiteCol]
@siteId int,
@colNum int
AS
BEGIN
SET NOCOUNT ON;

create Table #portDetail
(
ddfId int,
portDetail nvarchar(50),
siteId int
)
Insert into #portDetail SELECT  ddf.id,  ddf.portDetail, site.Site_ID  from site
        inner join ddf ON site.Site_ID = ddf.siteCodeID 
        where ddf.siteCodeID = @siteId and ddf.colNo= @colNum
        order by colNo,blockNum,portRowNum,portColNum

create Table #portAllocationDetail
(
assigned_slot nvarchar(50),
siteId int
)
Insert into #portAllocationDetail 
SELECT  dbo.portList.assigned_slot, dbo.site.Site_ID
FROM dbo.portList INNER JOIN
 dbo.site ON dbo.portList.siteCodeID = dbo.site.Site_ID
 where dbo.site.Site_ID = @siteId

--select * from #portAllocationDetail   
Select #portDetail.ddfId,#portDetail.portDetail,#portAllocationDetail.siteId,#portAllocationDetail.assigned_slot FROM #portDetail 
INNER JOIN #portAllocationDetail 
ON
#portDetail.siteId = #portAllocationDetail.siteId
END
4

4 回答 4

25

Aninner join为 TableA 中的每一行重复 TableB 中的每个匹配行。因此,如果 TableA 中有 4 行,TableB 中有 7 行,则最大行数为 28。

SQL Fiddle 的示例。

于 2012-09-12T13:35:25.980 回答
0

内连接返回满足条件的表的笛卡尔积的子集。因此,对于具有行 n 和 m 以及条件 True 的两个表 A 和 B,连接返回 nxm 行,这是最大值。

令人难以置信的是,如果我们使用正确的术语,这个解释会多么简单,但是我需要更多的时间来理解它“简单的方式”,这是大多数教程中解释的方式:(。

于 2022-01-05T01:38:48.867 回答
-2

----------内连接意味着-当两个表中至少有一个匹配时,INNER JOIN 关键字返回行。--

于 2013-01-11T11:03:55.323 回答
-2

内部连接也会导致重复。

如果您想要两个表中的唯一公共值,请使用相交运算符。

所以,这里 intersect 如果两边都为空,甚至可以显示空值。

于 2019-04-25T17:12:10.750 回答