zoukankan      html  css  js  c++  java
  • 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方法。

    运行结果与内联接相同。

  • 相关阅读:
    HDU 4031 Attack(离线+线段树)(The 36th ACM/ICPC Asia Regional Chengdu Site —— Online Contest)
    BZOJ 1010 玩具装箱toy(四边形不等式优化DP)(HNOI 2008)
    分布式事务二阶提交DTS系统
    flume原理及代码实现
    Liferay JSP Tag Libraries介绍
    如何用maven tycho构建自己的Eclipse RCP应用
    如何合并两个git commit
    推荐一个好用的git图形化工具
    git gc干了啥
    如何把VS Code的Language Server Protocol整合到Eclipse中来
  • 原文地址:https://www.cnblogs.com/mcgrady/p/3107020.html
Copyright © 2011-2022 走看看