我正在编写一个LINQ到SQL语句,并且我在c#中使用ON子句的正常内部连接的标准语法之后。

如何在LINQ to SQL中表示以下内容:

select DealerContact.*
from Dealer 
inner join DealerContact on Dealer.DealerID = DealerContact.DealerID

当前回答

从d1在dealercontract中加入d2在dealercontract中d1.dealearid = d2.dealerid select new {dealercontract.*}

其他回答

var list = (from u in db.Users join c in db.Customers on u.CustomerId equals c.CustomerId where u.Username == username
   select new {u.UserId, u.CustomerId, u.ClientId, u.RoleId, u.Username, u.Email, u.Password, u.Salt, u.Hint1, u.Hint2, u.Hint3, u.Locked, u.Active,c.ProfilePic}).First();

编写所需的表名,并初始化select以获得字段的结果。

创建一个外键,LINQ-to-SQL为您创建导航属性。然后每个Dealer都有一个DealerContacts集合,您可以选择、筛选和操作这些DealerContacts。

from contact in dealer.DealerContacts select contact

or

context.Dealers.Select(d => d.DealerContacts)

如果不使用导航属性,就会错过LINQ-to-SQL的一个主要好处——映射对象图的部分。

通过Clever Human扩展表达式链语法答案:

如果你想对两个表中的字段进行过滤或选择,而不是只对其中一个表进行操作,你可以在Join方法的最终参数的lambda表达式中创建一个新对象,将这两个表合并在一起,例如:

var dealerInfo = DealerContact.Join(Dealer, 
                              dc => dc.DealerId,
                              d => d.DealerId,
                              (dc, d) => new { DealerContact = dc, Dealer = d })
                          .Where(dc_d => dc_d.Dealer.FirstName == "Glenn" 
                              && dc_d.DealerContact.City == "Chicago")
                          .Select(dc_d => new {
                              dc_d.Dealer.DealerID,
                              dc_d.Dealer.FirstName,
                              dc_d.Dealer.LastName,
                              dc_d.DealerContact.City,
                              dc_d.DealerContact.State });

有趣的部分是该示例的第4行中的lambda表达式:

(dc, d) => new { DealerContact = dc, Dealer = d }

…在这里,我们构造了一个新的匿名类型对象,该对象具有DealerContact和Dealer记录的属性,以及它们的所有字段。

然后,我们可以在筛选和选择结果时使用这些记录中的字段,示例的其余部分演示了这一点,该示例使用dc_d作为我们构建的匿名对象的名称,该对象的属性是DealerContact和Dealer记录。

从d1在dealercontract中加入d2在dealercontract中d1.dealearid = d2.dealerid select new {dealercontract.*}

实际上,在linq中,通常最好不要加入。当有导航属性时,一个非常简洁的方式来写你的linq语句是:

from dealer in db.Dealers
from contact in dealer.DealerContacts
select new { whatever you need from dealer or contact }

它转换为where子句:

SELECT <columns>
FROM Dealer, DealerContact
WHERE Dealer.DealerID = DealerContact.DealerID