[英]How to do an Inner Join in LINQ
我有一條Linq語句,可將數據檢索到我的JAVASCRIPT表中。 我想做的是顯示廣告活動的歸檔者。 我需要將其加入我的MSCDB.Tbl_Users到Campaign表中。 有人可以嘗試給我一些幫助嗎? 我對LINQ相當陌生。
MSCDatabaseDataContext MSCDB = new MSCDatabaseDataContext();
var q = from row in MSCDB.Tbl_Campaigns
where row.CampaignStatus == 4
select new ArchiveReport
{
CampaignId = row.CampaignId,
CampaignName = row.CampaignName,
CampaignDescription = row.CampaignDescription,
CurrentStatus = row.EndDate >= DateTime.Now && row.StartDate <= DateTime.Now ? "Active" : row.StartDate >= DateTime.Now ? "Pending" : row.CampaignStatus == 4 ? "Archived" : "Closed",
CampaignStartDatesS = Convert.ToDateTime(row.StartDate).Date + " - " + Convert.ToDateTime(row.EndDate).Date,
Discount = Convert.ToInt32(row.Discount),
Target = Convert.ToInt32(row.Target),
Uptake = Convert.ToInt32(row.Uptake),
DateArchived = Convert.ToDateTime(row.DateArchived),
ArchivedBy = Convert.ToInt32(row.ArchivedBy)
};
我不確定您的數據庫結構如何,但是如果Tbl_Users
具有CampaignId
,則應該這樣:
MSCDatabaseDataContext MSCDB = new MSCDatabaseDataContext();
var q = from row in MSCDB.Tbl_Campaigns
//here is your join
join usr in MSCDB.Tbl_Users on row.CampaignId equals usr.CampaignId
//-------------------------
where row.CampaignStatus == 4
select new ArchiveReport
{
//Here how you can jet values from user table
UserName = usr.Name,
//-------------------------
CampaignId = row.CampaignId,
CampaignName = row.CampaignName,
CampaignDescription = row.CampaignDescription,
CurrentStatus = row.EndDate >= DateTime.Now && row.StartDate <= DateTime.Now ? "Active" : row.StartDate >= DateTime.Now ? "Pending" : row.CampaignStatus == 4 ? "Archived" : "Closed",
CampaignStartDatesS = Convert.ToDateTime(row.StartDate).Date + " - " + Convert.ToDateTime(row.EndDate).Date,
Discount = Convert.ToInt32(row.Discount),
Target = Convert.ToInt32(row.Target),
Uptake = Convert.ToInt32(row.Uptake),
DateArchived = Convert.ToDateTime(row.DateArchived),
ArchivedBy = Convert.ToInt32(row.ArchivedBy)
};
示例代碼為
var q= from row in MSCDB.Tbl_Campaigns
join user in MSCDB.Tbl_Users
on row.UserId equals user.ID
select row;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.