/*********************Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习**********************************/
            //判断没有成绩的学生
            var list = from s in ctx.T_Student
                       where !s.T_Score.Any()
                       select s;
            //判断有成绩大于80的学生
            var list1 = (from s in ctx.T_Student
                         where s.T_Score.Any(t => t.score > 80)
                         select s).Distinct();
            //所有科目成绩大于80的学生
            var list2 = from s in ctx.T_Student
                        where s.T_Score.All(t=>t.score>80)
                        select s;
            //查询黄阳是否参加过考试
            string[] names = { "黄阳"};
            var list4 = from s in ctx.T_Score
                        where names.Contains(s.T_Student.stuName)
                        select s;
            //查询黄阳是否参加过考试
            var list3 = from s in ctx.T_Score
                        where (new string[] { "黄阳" }).Contains(s.T_Student.stuName)
                        select s;
            //参加过考试但是不是黄阳的同学
            var list5 = from s in ctx.T_Score
                        where !(new string[] { "黄阳" }).Contains(s.T_Student.stuName)
                        select s;
            //contains也可以包含一个对象,如查询那些学生参加了课程编号为001的第一个同学,对于contains只能包含一个实体,不能保护实体集
            var temp1 = (from s in ctx.T_Score
                        where s.stuNumber == "001"
                        select s).First();
            var result = ctx.T_Student.Where(p=>p.T_Score.Contains(temp1));
            //查找黄阳和黄波的所有成绩
            string[] names1 = {"黄阳","黄波"};
            var result2 = ctx.T_Score.Where(f=>names1.Contains(f.T_Student.stuName));
            //或者也可以这样
            var result3 = from s in ctx.T_Score
                          where (new string[] { "黄阳", "黄波" }).Contains(s.T_Student.stuName)
                          select s;
            //对于concat,连接不同的集合,不会自动过滤相同项,而且它只能对于单列进行连接,对多列进行连接,会报语法错误,因为没有相应的扩展方法

var result4 = (from s in ctx.T_Student
                           select s.stuName)
                          .Concat(from k in ctx.T_Score
                                  select k.T_Cource.courceName );
            //合并所有的学生
            var result5 = ((from s in ctx.T_Student
                            select s.stuNumber)
                        .Union
                        (from k in ctx.T_Score
                         select k.stuNumber)).Distinct();
            //交集
            var result6 = (from s in ctx.T_Student
                           select s.stuNumber).Intersect
                          (from k in ctx.T_Score
                               select k.stuNumber);
            //差集
            var result7 = (from s in ctx.T_Student
                           select s.stuNumber).Intersect
                               (from k in ctx.T_Score
                                select k.stuNumber);
            //查询前三个学生的信息
            var result8 = (from s in ctx.T_Student
                          select s).Take(3);
            //查询三个学生以外的所有学生信息
            var result9 = (from s in ctx.T_Student
                               select s).Skip(3);
            //当学号为2091723时候,就停止获取学生信息
            var result10 = (from s in ctx.T_Student
                            select s).TakeWhile(k => k.stuNumber == "2091723");
            //当学号为2091723时候,就停止跳过学生信息,并获取后边的所有学生信息
            var result11 = (from s in ctx.T_Student
                            select s).SkipWhile(k => k.stuNumber == "2091723");
            //可以用skip和take来对数据进行分页,这非常方便

//查看姓名以黄开头的学生信息,这时候程序需要引入using System.Data.Linq.SqlClient;命名空间
            var result12 = from s in ctx.T_Student
                           where SqlMethods.Like(s.stuName,"黄%")
                           select s;
            //查询学号为2X917X2的学生
            var result13 = from s in ctx.T_Student
                           where SqlMethods.Like(s.stuNumber, "2_917_2")
                           select s;
            //比较时间的操作分别有:DateDiffDay、DateDiffHour、DateDiffMillisecond、DateDiffMinute、DateDiffMonth、DateDiffSecond、DateDiffYear ,也是sqlMethods方法,而数据库中的表并没有设计时间的字段,所以就不演示了

//SQL语句进行编辑重新查询,需要引用命名空间using System.Data.Linq;
            var fn = CompiledQuery.Compile(
                (DB_StudentDataContext ctx1,string stuName)=>
                from s in ctx1.T_Student
                where s.stuName==stuName
                select s
                );
            var data1 = fn(ctx,"黄阳");
            var data2 = fn(ctx,"黄波");

Linq无聊练习系列6--Any/All/Contains/Concat/Union/Intersect/Except/take/skip/SqlMethods操作练习的更多相关文章

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

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

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

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

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

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

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

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

  5. Linq无聊练习系列4--join练习

    /**************join 练习*******************/            //对于1对多关系            var list =from c in ctx.T ...

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

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

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

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

  8. LINQ to SQL语句(8)之Concat/Union/Intersect/Except

    适用场景:对两个集合的处理,例如追加.合并.取相同项.相交项等等. Concat(连接) 说明:连接不同的集合,不会自动过滤相同项:延迟. 1.简单形式: var q = ( from c in db ...

  9. LINQ to Sql系列一 增,删,改

    首先,我们来了解一下LINQ to sql 是什么,我想从以下几点来做说明. 1,LINQ是从.net framework 3.0开始引入的的语言特性,主要是用来对集合数据进行操作的.2,LINQ t ...

随机推荐

  1. JavaScript通告/订阅的例子

    原文链接: Pub/Sub JavaScript Object原始日期: 2014年6一个月11日本: 2014年6月13日 翻译人员: 铁锚 高效AJAX站点的三大杀器: 事件代理, 浏览历史管理, ...

  2. Chain of Responsibility - 责任链模式

    定义 使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合度. 案例 比方如今有一个图形界面,它包含一个应用Application类,一个主窗体Window,一个buttonButton ...

  3. OCP读书笔记(23) - 题库(ExamC)

    200.Which operation requires that you create an auxiliary instance manually before executing the ope ...

  4. .NET系统开发过程中积累的扩展方法

    分享.NET系统开发过程中积累的扩展方法   .NET 3.5提供的扩展方法特性,可以在不修改原类型代码的情况下扩展它的功能.下面分享的这些扩展方法大部分来自于Code Project或是Stacko ...

  5. Codeforces Round #306 (Div. 2) C

    意甲冠军 到不超过一个更100该整数字符串.采取随机从数间(不能拿). 问:是否有可能被剩下8除尽.假设能,出口YES和任选一个数字的其余病例的. 不能够,输出NO. 思路 想法题. 首先观察到.10 ...

  6. redis权限认证(设置密码)的方法

    redis可以通过设置密码来增强安全强度.除了设置密码,我们还可以通过修改redis的默认端口.对端口做防火墙等.那么如何开启redis的密码功能呢?以下就是详细的步骤方法: 打开redis.conf ...

  7. HDU 3117 Fibonacci Numbers(围绕四个租赁斐波那契,通过计++乘坐高速动力矩阵)

    HDU 3117 Fibonacci Numbers(斐波那契前后四位,打表+取对+矩阵高速幂) ACM 题目地址:HDU 3117 Fibonacci Numbers 题意:  求第n个斐波那契数的 ...

  8. 学习javascript 的一点感想

    原文:学习javascript 的一点感想 //动态性是指,在一个Javascript对象中,要为一个属性赋值,我们不必事先创建一个字段,只需要在使用的时候做赋值操作即可,如下例:var obj=ne ...

  9. js敏感词过滤

    var filterWord={ words:"", tblRoot:{}, //敏感词文件 file:"sensitiveWords.txt", //载入敏感 ...

  10. [cocos2d-x 3.0] 触摸显示器

    一.基本使用 1.首先,声明一个监听器 有两种,EventListenerTouchOneByOne 和 EventListenerTouchAllAtOnce,前者是单点触控.后者是多点触控.后者我 ...