我有两个强类型的数据表 (dt1
):
|FirstName|LastName|Val1|Val2|
|Tony |Stark |34 |35 |
|Steve |Rogers |12 |23 |
|Natasha |Romanoff|2 |100 |
和第二个 (dt2
)
|FirstName|LastName|Val1|Val2|
|Tony |Stark |16 |5 |
|Bruce |Banner |2 |1 |
|Steve |Rogers |54 |40 |
我将尝试创建一个新的数据表,其中我将为人员的价值相加。我需要进行外部连接,因为我需要所有人员,并且第二个表中的值减半。
因此,结果应该如下所示:
|FirstName|LastName|Val1|Val2|
|Tony |Stark |42 |37.5|
|Steve |Rogers |39 |43 |
|Natasha |Romanoff|2 |100 |
|Bruce |Banner |1 |0.5 |
我的方法是使用LINQ:
Dim query =
from a in ds1.Table1
Join b in ds2.Table2
On a.FirstName + a.LastName Equals b.FirstName + b.Lastname
Select New With {
.FirstName = a.FirstName,
.LastName = a.LastName,
.Val1 = a.Val1 + b.Val1 *0.5,
.Val2 = a.Val2 + b.Val2 *0.5
}
但我不太理解所有人都采用这种方法。我也尝试过。
Dim query =
From a in ds1.Table1
From b in ds2.Table2
Select New With{
Key .KeyName = a.FirstName + a.LastName = b.FirstName + b.FirstName,
.Val1 = a.Val1 + b.Val1 *0.5,
.Val2 = a.Val2 + b.Val2 * 0.5
}
现在,每个人都有很多条目。有没有人能帮我完成这个任务?我不知道是否有其他方法可以解决,而不需要使用Linq。
.DefaultIfEmpty()
,你需要先进行左外连接再进行右外连接,这样就能得到全连接了。 - Victor Zakharov