你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
内部联接
适用于:✅Microsoft Fabric✅Azure 数据资源管理器Azure Monitor✅Microsoft✅ Sentinel
inner
联方式类似于 SQL 中的标准内联。 只要左侧的记录具有与右侧记录相同的联接键,就会生成输出记录。
语法
LeftTable |
join
kind=inner
[ Hints ] RightTable on
Conditions
详细了解语法约定。
参数
客户 | 类型 | 必需 | 说明 |
---|---|---|---|
LeftTable | string |
✔️ | 要合并其行的左侧表或表格表达式(有时称为外部表)。 表示为 $left 。 |
提示 | string |
零个或多个(以空格分隔)以 Name = Value 形式表示的联接提示,用于控制行匹配操作和执行计划的行为。 有关详细信息,请参阅提示。 |
|
RightTable | string |
✔️ | 要合并其行的右侧表或表格表达式(有时称为内部表)。 表示为 $right 。 |
条件 | string |
✔️ | 确定 LeftTable 中的行如何与 RightTable 中的行匹配。 如果要匹配的列在这两个表中具有相同的名称,请使用 ON ColumnName 语法。 否则,请使用 ON $left. LeftColumn == $right. RightColumn 语法。 若要指定多个条件,可以使用“and”关键字,也可以使用逗号分隔它们。 如果使用逗号,则将使用“and”逻辑运算符来计算条件。 |
提示
为获得最佳性能,如果某个表始终小于另一个表,则将其用作 join 的左侧。
提示
参数名称 | 值 | 说明 |
---|---|---|
hint.remote |
auto 、、left local 、、right |
请参阅跨群集联接 |
hint.strategy=broadcast |
指定在群集节点上共享查询负载的方式。 | 请参阅广播联接 |
hint.shufflekey=<key> |
shufflekey 查询使用键将数据分区,在群集节点上共享查询负载。 |
请参阅 shuffle 查询 |
hint.strategy=shuffle |
shuffle 策略查询会在群集节点上共享查询负载,其中的每个节点将处理一个数据分区。 |
请参阅 shuffle 查询 |
返回
架构:两个表中的所有列,包括匹配的键。
行:仅限两个表中匹配的行。
示例
let X = datatable(Key:string, Value1:long)
[
'a',1,
'b',2,
'b',3,
'k',5,
'c',4
];
let Y = datatable(Key:string, Value2:long)
[
'b',10,
'c',20,
'c',30,
'd',40,
'k',50
];
X | join kind=inner Y on Key
输出
键 | Value1 | Key1 | Value2 |
---|---|---|---|
b | 3 | b | 10 |
b | 2 | b | 10 |
c | 4 | c | 20 |
c | 4 | c | 30 |
k | 5 | k | 50 |
注意
- 右侧的 (b,10) 联接了两次:与左侧的 (b,2) 和 (b,3) 都进行了联接。
- 左侧的 (c,4) 联接了两次:与右侧的 (c,20) 和 (c,30) 都进行了联接。
- 自左到右的 (k,5) 和自右到左的 (k, 50) 联接了一次。
相关内容
- 了解其他联接方式