There are 2 tables:
data:image/s3,"s3://crabby-images/07fd5/07fd592fbb8f1311708cdd0a2d243c9238f7538f" alt=""
data:image/s3,"s3://crabby-images/51ef0/51ef09443b5879bcfa987b2a0017b3cb2b2c36fd" alt=""
Auto text is the left table. Its customer column holds the Id for Customer table's elements. My task was, if there is a value in the Autotext.Customer field, then I have to show the relevant customer name. And if the value is null then it would show n\a. Only performing a left outer join can solve this. And this is how I solved it:
public IEnumerable GetAutotextsWithCustomerNameLeftJoin(int customerId)
{
try
{
IEnumerable AutotextsWithCustomerName = from AutotextTable in this.Context.AutoTexts
join CustomerTable in this.Context.Customers
on AutotextTable.Customer equals CustomerTable.Id into temporaryTable
from xTable in temporaryTable.DefaultIfEmpty()
select new { AutotextTable.Id, AutotextTable.Key, AutotextTable.Value, CustomerName = xTable.Id==null?"n\a":xTable.Name };
return AutotextsWithCustomerName;
}
catch (Exception ex)
{
return null;
}
}
Here, temporaryTable is the table that is created after the join operation is performed. xTable is the table that is created after left outer join is performed.
This solved the problem. I took help from different online posts. But, this post helped me the most:
LEFT OUTER JOIN in LINQ To SQL
No comments:
Post a Comment