• LINQ to Sql系列二 简单查询和联接查询


    这一篇文章主要总结LINQ to sql的简单查询(单表查询)和联接查询(多表查询)

    单表查询

    需求是我们要输出TClass表中的结果。使用了from…in…select语句,代码如下:

    复制代码
    public static void SimpleQuery()
            {
                using (L2SDBDataContext db = new L2SDBDataContext())
                {
                    var query = from tc in db.TClasses
                                //select tc;
                                select new { 
                                    ClassID=tc.ClassID,
                                    ClassName=tc.ClassName
                                };
                    Console.WriteLine("output results for table of class");
                    int i = 1;
                    foreach (var item in query)
                    {
                        Console.WriteLine("{0},ClassID:{1},ClassName:{2}",i,item.ClassID,item.ClassName);
                        i++;
                    }
                }
            }
    复制代码

    注意:这里没有用select tc,而是定义了一个新的匿名类型是因为性能的考虑,后面性能优化的部分会讲到。

    输出结果:

    l2s06

    多表查询

    多表查询,也可以称为联接查询,需要通过外键联接多张表才能查询到我们想要的结果,现在的需求是某个班级及这个班级相关学生的信息。实现这个需求有两种方法,一种是内联接,另一种方法是外联接,下面是通过内联接查询的代码。

    复制代码
    public static void Query_InnerJoin()
            {
                using (L2SDBDataContext db = new L2SDBDataContext())
                {
                    var query = from s in db.TStudents
                                join c in db.TClasses on s.ClassID equals c.ClassID
                                where s.ClassID == 3
                                select new
                                {
                                    ClassID = s.ClassID,
                                    ClassName = c.ClassName,
                                    Student = new
                                    {
                                        Name = s.Name,
                                        StudentID = s.StudentID
                                    }
                                };
    
                    foreach (var item in query)
                    {
                        Console.WriteLine("{0} {1} {2}", item.ClassID, item.ClassName, item.Student.Name);
                    }    
                }
            }
    复制代码

    运行结果:

    l2s07

    外联接代码:

    复制代码
    public static void Query_OutJoin()
            {
                using (L2SDBDataContext db = new L2SDBDataContext())
                {
                    var query = from s in db.TStudents
                                join c in db.TClasses on s.ClassID equals c.ClassID into gc
                                from gci in gc.DefaultIfEmpty()
                                where s.ClassID == 3
                                select new
                                {
                                    ClassID = s.ClassID,
                                    ClassName = gci.ClassName,
                                    Student = new
                                    {
                                        Name = s.Name,
                                        StudentID = s.StudentID
                                    }
                                };
    
                    foreach (var item in query)
                    {
                        Console.WriteLine("{0}, {1} [{2}]", item.ClassID, item.ClassName, item.Student.Name);
                    }
                }
            }
    复制代码

    注意:outer join时必须将join后的表into到一个新的变量中,然后调用这个对象的DefaultIfEmpty方法。

    运行结果与内联接相同。

  • 相关阅读:
    python拆包与装包-*args,**kwargs
    mybatis学习4-CRUD操作
    mybatis学习3-入门案例,注解方式
    mybatis学习1-前置,复习Jdbc
    spring框架学习-aop
    spring学习1-第一个spring项目
    spring概述
    idea的一些个人设置
    maven的一些个人设置
    VBA文件对话框的应用(VBA打开文件、VBA选择文件、VBA选择文件夹,VBA遍历文件夹)
  • 原文地址:https://www.cnblogs.com/wlming/p/5993745.html
Copyright © 2020-2023  润新知