/**************join 练习*******************/
            //对于1对多关系
            var list =from c in ctx.T_Student
                      from s in c.T_Score
                      where c.stuName=="黄阳"
                      select s;
            //也可以间接的通过表关联其它表,这个结果和上边的查询结果相同
            var list1 = from s in ctx.T_Score
                        where s.T_Student.stuName=="黄阳"
                        select s;
            //多对多关系,他们之间的关系是1:M:1
            var list2 = from s in ctx.T_Cource
                        from c in s.T_Score
                        select new {
                            s.courceName,
                            c.score,
                            c.T_Student.stuName
                        };
            //如果表里边有隶属关系,可以使用自联结,由于表的设计不是很好,所以没有包括这种情况
            //双向链接
            var list3 = from s in ctx.T_Student
                        join t in ctx.T_Score
                        on s.stuNumber
                        equals t.stuNumber
                        into g
                        select new {
                           stuName =  s.stuName,
                           score = g.Sum(k=>k.score)               
                        };
            //三向链接
            var list4 = from s in ctx.T_Score
                        join c in ctx.T_Cource
                        on s.courceNumber
                        equals c.courceNumber into temp1
                        join t in ctx.T_Student
                        on s.stuNumber
                        equals t.stuNumber into temp2
                        select new {
                           Score = s.score,
                           Name = temp1.Count()
                        };
            //左外部链接
            var list5 = from s in ctx.T_Student
                        join c in ctx.T_Score
                        on s.stuNumber
                        equals c.stuNumber
                        into temp1
                        from k in temp1.DefaultIfEmpty()
                        select new
                        {
                            stuName = s.stuName,
                            sumScore = k.score
                        };
            //投影的let操作
            var list6 = from s in ctx.T_Student
                        join c in ctx.T_Score
                        on s.stuNumber
                        equals c.stuNumber into temp1
                        let studentInfo = s.stuName +s.stuSex
                        from k in temp1
                        select new {
                            stuNumber=s.stuNumber,
                            CoreOfStudents = k.score,
                            studentInfomation = studentInfo
                        };
                //使用组合健来表示多表之间的关系 ,这个由于表中设计时候,基本只有一个主键,没有用到联合主键  
            //一侧可为空另一侧不能为空的链接
            var list7 = from s in ctx.T_Student
                        join c in ctx.T_Score
                        on Convert.ToInt32(s.stuNumber)
                        equals (int ?)Convert.ToInt32(c.stuNumber) into temp1
                        select new {
                            stuName = s.stuNumber,
                            sumCore = temp1.Sum(f=>f.score)
                        };

Linq无聊练习系列4--join练习的更多相关文章

  1. Linq无聊练习系列8---开放式并发事务,null和 DateTime,string操作练习

    /*********************开放式并发事务,null和 DateTime,string操作练习**********************************/ //所谓并发,就是 ...

  2. Linq无聊练习系列6--Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习

    /*********************Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习******* ...

  3. Linq无聊练习系列5--OrderBy ,Groupby练习

    /**************OrderBy ,Groupby练习*******************/                       //按学生的总分数按降序排列排序         ...

  4. Linq无聊练习系列1--where练习

    linq主要有3种,linq to sql,linq to XML,Linq to Object linq to sql. 这里没有通过相应的类,生成相应的数据库中的表.没有用流行的编码优先. 只是为 ...

  5. Linq无聊练习系列7----Insert,delete,update,attach操作练习

    /*********************Insert,delete,update,attach操作练习**********************************/            ...

  6. Linq无聊练习系列3--聚合函数练习

    /**************聚合函数 练习*******************/            //求学生的总数量            var list = ctx.T_Student. ...

  7. Linq无聊练习系列2--select/distinct练习

    void dataBindByWhere()        { /**************select/distinct 练习*******************/            //获 ...

  8. Linq 多表连接查询join

    在查询语言中,通常需要使用联接操作.在 LINQ 中,可以通过 join 子句实现联接操作.join 子句可以将来自不同源序列,并且在对象模型中没有直接关系(数据库表之间没有关系)的元素相关联,唯一的 ...

  9. LINQ TO SQL 中的join(转帖)

    http://www.cnblogs.com/ASPNET2008/archive/2008/12/21/1358152.html join对于喜欢写SQL的朋友来说还是比较实用,也比较容易接受的东西 ...

随机推荐

  1. Android之Http沟通——4.Android HTTP索取信息:HttpClient

    本节介绍: 他谈到了部分HttpURLConnection.本节HttpClient该,Apache为我们提供HttpClient(简单的Http客户端),只是毕竟不是亲儿子.HttpClient在A ...

  2. Lampda或Linq中的SqlFunctions.StringConvert()

    要使用 Lampda或Linq中的SqlFunctions.StringConvert(), 需要引用命名空间using System.Data.Objects.SqlClient, 该函数可进行模拟 ...

  3. kendo ui 单击取消编辑数据grid减少的原因和治疗方法的数据

    kendo ui单击取消编辑数据buttongrid数据缩减.原因grid编辑数据追打datasorce于data寻找阵列数据的存在.假定有不会加入,加入缺席. 首先一个样本: html代码: < ...

  4. ABP领域层——实体

    ABP领域层——实体 基于DDD的现代ASP.NET开发框架--ABP系列之10.ABP领域层——实体 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的 ...

  5. Hadoop-1.1.2、HBase-0.94.7完全分布式集群结构

    爱的技术可以应用到实际生活生产,做艺术向往的东西不腻和音乐. 现将前期手里面的一个项目做一个大致的总结,与大家一起分享.交流.进步. 项目如今正在线上执行,项目名--基于Hadoop的数据分析综合管理 ...

  6. 经典算法题每日演练——第八题 AC自动机

    原文:经典算法题每日演练--第八题 AC自动机 上一篇我们说了单模式匹配算法KMP,现在我们有需求了,我要检查一篇文章中是否有某些敏感词,这其实就是多模式匹配的问题. 当然你也可以用KMP算法求出,那 ...

  7. root运行/media可运行文件权限不够,chmod改动权限无效

    http://blog.csdn.net/pipisorry/article/details/39649699 问题: 我想运行media目录下自己写的某个程序,但无法运行? 1. 于是我以root的 ...

  8. 启用IIS7报错功能

    进入:控制面板 - 卸载程序 - 打开或关闭Windows功能 如果访问任何不存在页面或页面出错时空白: Internet 信息服务 - 万维网服务 - 常见 HTTP 功能 - HTTP 错误 打勾 ...

  9. IOS程序创建view

    在IOS程序中创建view有六种方式 首先创建一个GLViewController类,继承UIViewController. 然后进入GLAppDelegate.m,在- (BOOL)applicat ...

  10. Java-DES算法加密解密工具类

    import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.InputStream; import ...