LINQ To Entity - Easy Left Join

Hi Experts!

Thanks for reading this.

Trying to convert this T-SQL to Linq to Entity:
SELECT 
  sq.SurveyQuestionText
, sac.SurveyScaleText
FROM [dbo].SurveyQuestions sq
LEFT JOIN 
			(
			SELECT 
			 sa.SurveyQuestionID
			, sc.SurveyScaleText
			FROM SurveyUserAnswers sa
			INNER JOIN SurveyScales as sc
				ON sa.SurveyScaleID = sc.SurveyScaleID
			WHERE sa.UserID = 2
			) As sac
			ON sq.SurveyQuestionID = sac.SurveyQuestionID
WHERE sq.SurveyQuestionCounter <= 10 

Open in new window

This is the INNER JOIN:
SomeDB db = new SomeDB();
var UserAnswered = (from ua in db.SurveyUserAnswers
                    join s in db.SurveyScales on ua.SurveyScaleID equals s.SurveyScaleID
                    where ua.UserID == 2
                    select new 
                    { 
                        ua.SurveyQuestionID,
                        s.SurveyScaleText
                    }).ToList();

Open in new window

A LEFT JOIN looks like this:
var query = (from sq in SurveyQuestions
            from sac in  //UserAnswered above
                             .Where(x => sq.SurveyQuestionID == x.SurveyQuestionID)
                             .DefaultIfEmpty()
            select new
			{sq.SurveyQuestionText
             ,sac.SurveyScaleText}).ToList();

Open in new window


Stuck trying to put the two pieces together.

The query would return All questions and if the user has answered the question it would be null for UserAnswered.

Any ideas? TIA!

If you need more info... This will create the class:
public class SurveyUserAnswer
{
    [Key, Required]
    public int SurveyUserAnswerID { get; set; }
    [Required]
    public int SurveyScaleID { get; set; }
    [Required]
    public int SurveyQuestionID { get; set; }
    [Required]
    public int UserID { get; set; }
    public DateTime DateCreated { get; set; }

    public virtual SurveyScale SurveyScale { get; set; }
    public virtual SurveyQuestion SurveyQuestion { get; set; }
    public virtual User User { get; set; }

    public SurveyUserAnswer()
    {
        DateCreated = DateTime.UtcNow;
    }
}


public class SurveyQuestion
{
    [Key, Required]
    public int SurveyQuestionID { get; set; }
    [Required]
    public int SurveyQuestionCounter { get; set; }
    [Required, MaxLength(500)]
    public string SurveyQuestionText { get; set; }
    public DateTime DateCreated { get; set; }

    public virtual ICollection<SurveyUserAnswer> SurveyUserAnswer { get; set; }

    public SurveyQuestion()
    {
        DateCreated = DateTime.UtcNow;
    }
}

public class SurveyScale
{
    [Key, Required]
    public int SurveyScaleID { get; set; }
    [Required]
    public int SurveyScaleValue { get; set; }
    [Required, MaxLength(8)]
    public string SurveyScaleText { get; set; }
    public DateTime DateCreated { get; set; }

    public virtual ICollection<SurveyUserAnswer> SurveyUserAnswer { get; set; }

    public SurveyScale()
    {
        DateCreated = DateTime.UtcNow;
    }
}

Open in new window

This will create the dummy data content:
        var SurveyScales = new List<SurveyScale> 
        {
        new SurveyScale {SurveyScaleValue = 0, SurveyScaleText = "Never"},
        new SurveyScale {SurveyScaleValue = 1, SurveyScaleText = "Seldom"},
        new SurveyScale {SurveyScaleValue = 2, SurveyScaleText = "Sometime"},
        new SurveyScale {SurveyScaleValue = 3, SurveyScaleText = "Always"}
        };
        SurveyScales.ForEach(r => db.SurveyScales.Add(r));
        db.SaveChanges();

        var SurveyQuestions = new List<SurveyQuestion>
        {
            new SurveyQuestion {SurveyQuestionCounter = 1, SurveyQuestionText = "Question A"},
            new SurveyQuestion {SurveyQuestionCounter = 2, SurveyQuestionText = "Question B"},
            new SurveyQuestion {SurveyQuestionCounter = 3, SurveyQuestionText = "Question C"},
            new SurveyQuestion {SurveyQuestionCounter = 4, SurveyQuestionText = "Question D"}
        };
        SurveyQuestions.ForEach(r => db.SurveyQuestions.Add(r));
        db.SaveChanges();

        var SurveyUserAnswers = new List<SurveyUserAnswer>
        {
            new SurveyUserAnswer {SurveyScaleID = 1,  SurveyQuestionID = 1,  UserID = 1},
            new SurveyUserAnswer {SurveyScaleID = 2,  SurveyQuestionID = 2,  UserID = 1},
            new SurveyUserAnswer {SurveyScaleID = 3,  SurveyQuestionID = 3,  UserID = 1},
            new SurveyUserAnswer {SurveyScaleID = 4,  SurveyQuestionID = 4,  UserID = 1},

            new SurveyUserAnswer {SurveyScaleID = 1,  SurveyQuestionID = 1,  UserID = 2},
            new SurveyUserAnswer {SurveyScaleID = 2,  SurveyQuestionID = 2,  UserID = 2}          
        };
        SurveyUserAnswers.ForEach(r => db.SurveyUserAnswers.Add(r));
        db.SaveChanges();

Open in new window

LVL 5
allanau20Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Bob LearnedCommented:
You should be able to combine those two queries, if you take advantage of LINQ's laziness.  That means that you need to stay away from things that execute, like ToList.

Example:

var UserAnswered = (from ua in db.SurveyUserAnswers
                    join s in db.SurveyScales on ua.SurveyScaleID equals s.SurveyScaleID
                    where ua.UserID == 2
                    select new 
                    { 
                        ua.SurveyQuestionID,
                        s.SurveyScaleText
                    });

var query = (from sq in SurveyQuestions
            join sac in UserAnswered
                  on sq.SurveyQuestionID equals sac.SurveyQuestionID into leftJoin
            from result in leftJoin.DefaultIfEmpty()
            select new
			{sq.SurveyQuestionText,
                         sac.SurveyScaleText}).ToList();

Open in new window

0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
allanau20Author Commented:
Thanks TheLearnedOne; I will try it sometime later today ...
0
allanau20Author Commented:
took your solution and extended it:
var UserAnswered = (from ua in db.SurveyUserAnswers
                    join s in db.SurveyScales on ua.SurveyScaleID equals s.SurveyScaleID
                    where ua.UserID == 2
                    select new
                    {
                        ua.SurveyQuestionID,
                        s.SurveyScaleText,
                        s.SurveyScaleValue
                    });

var query = (from sq in db.SurveyQuestions
                join sac in UserAnswered
                    on sq.SurveyQuestionID equals sac.SurveyQuestionID into leftJoin
                from result in leftJoin.DefaultIfEmpty()
                where sq.SurveyQuestionCounter <= 10 
                select new
                {
                    sq.SurveyQuestionText,  
                    SurveyScaleText = result.SurveyScaleText != null ? result.SurveyScaleText : null,
                    SurveyScaleValue = result.SurveyScaleValue != null ? result.SurveyScaleValue : (int?)null        
                });

Open in new window

0
allanau20Author Commented:
Thanks for your help!!
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Query Syntax

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.