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

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

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

当前回答

使用Linq Join操作符:

var q =  from d in Dealer
         join dc in DealerConact on d.DealerID equals dc.DealerID
         select dc;

其他回答

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

通过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记录。

var data=(from t in db.your tableName(t1) 
          join s in db.yourothertablename(t2) on t1.fieldname equals t2.feldname
          (where condtion)).tolist();

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

from contact in dealer.DealerContacts select contact

or

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

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

试试这个吧,

var dealer = from d in Dealer
             join dc in DealerContact on d.DealerID equals dc.DealerID
             select d;