簡體   English   中英

在實體框架中將SQL轉換為Linq查詢

[英]Convert SQL to Linq queries in Entity Framework

如何在實體框架中將此查詢轉換為LINQ查詢? 我是還在上學的新程序員

SELECT 
    studfirstname, studlastname, grade
FROM 
    students
INNER JOIN 
    Student_Schedules ON students.StudentID = Student_Schedules.StudentID
INNER JOIN 
    Classes ON Student_Schedules.ClassID = Classes.ClassID
INNER JOIN 
    Subjects ON Classes.SubjectID = Subjects.SubjectID
WHERE 
    SubjectName = 'Introduction to Art';

正如你在Lambda和LINQ是新的我在下面LAMBDA試圖盡可能描述.....你可以使用長別名以簡短的形式也student_schedules作為ssstudentsANDstudent_schedules作為s_s_sch ......嘗試......希望這會有所幫助.... @Abdul Hameed

var filteredData = context.Students    // your starting point
   .Join(context.Student_Schedules, // the source table of the inner join
      students => students.StudentID,        // Select the primary key (the first part of the "on" clause in an sql "join" statement)
      student_schedules => student_schedules.StudentID),// the foreign key
      (students, student_schedules) => new { students, student_schedules })
   .Join(context.Classes,
      classes => classes.ClassID,        
      studentsANDstudent_schedules => studentsANDstudent_schedules.student_schedules.ClassID),
      (classes, studentsANDstudent_schedules) => new { classes, studentsANDstudent_schedules })
   .Join(context.Subjects,
      subjects => subjects.SubjectID,        
      studentsANDstudent_schedulesANDClasses => studentsANDstudent_schedulesANDClasses.classes.SubjectID),
      (subjects, studentsANDstudent_schedulesANDClasses) => new { subjects, studentsANDstudent_schedulesANDClasses })
   .Where(allMergedTables => allMergedTables.subjects.SubjectName == "Intoduction to Art").ToList();

這是以上版本的簡化版本...

var filteredData = context.Students 
   .Join(context.Student_Schedules, s => s.StudentID, sch => sch.StudentID),
      (s, sch) => new { s, sch })
   .Join(context.Classes, c => c.ClassID, s_sch => s_sch.sch.ClassID),
      (c, s_sch) => new { c, s_sch })
   .Join(context.Subjects, sj => sj.SubjectID, s_sch_c => s_sch_c.c.SubjectID), 
      (sj, s_sch_c) => new { sj, s_sch_c })
   .Where(all => all.sj.SubjectName == "Intoduction to Art")
   .ToList();

您可以使用LINQ語法:

from student in context.Students
join schedule in context.Student_Schedules on student.StudentID equals schedule.StudentID
join @class in context.Classes on schedule.ClassID equals @class.ClassID
join subject in context.Subjects on @class.SubjectID equals subject.SubjectID
where subject.SubjectName == "Introduction to Art"
var students = context.Students.Include("Student_Schedules")
                               .Include("Classes")
                               .Include("Subjects").Where(s => s.Subjects.Contains("Intoduction to Art"));

信息-> https://msdn.microsoft.com/zh-cn/data/jj574232.aspx

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM