#region linq的标准查询运算符(即lambda方式) 注:C#不支持标准查询运算符中带有整形参数(索引)的重载

// 1、标准查询运算符之筛选方法——where
            //IQueryable<Student> stu1=db.Student.Where(s => s.Ssex == "男");
            //GridView1.DataSource = stu1;
            //GridView1.DataBind();

// 2、标准查询运算符之s投影方法——select

//var stu2 =db.Student.Select(s => new {s.Sno,s.Sname,s.Sage}); //这叫匿名对象
            //GridView2.DataSource = stu2;
            //GridView2.DataBind();

//3、标准查询运算符之排序方法—— order
            //升序排序
            var stu3 = db.Student.OrderBy(s => s.Sage);
            GridView1.DataSource = stu3;
            GridView1.DataBind();

//降序排序之多条件排序
            var stu4 = db.Student.OrderByDescending(s => s.Sage).ThenByDescending(s=>s.Sno);
            GridView2.DataSource = stu4;
            GridView2.DataBind();

    //备注:OrderBy()和OrderDescendingBy()方法不会改变原列表 而是返回排序后的列表 这点是和Sort的不同之处之一。

    //pers.Sort((p1, p2) => p1.Age - p2.Age); //按照Age升序排序

//4、标准运算符之连接集合—— Join

    // 第一个参数:要连接的对象(B)第二个参数:A对象及A对象用来连接的字段;第三个参数:B对象及B对象用来连接的字段;第四个参数:A,B=>返回的对象
            var stu5 = db.Student.Join(db.StuCourse, s => s.Sno, stu => stu.Sno, (s, stu) => new { Sno=s.Sno,SCSno=stu.Sno,s.Sname,stu.Cid});
            GridView2.DataSource = stu5;
            GridView2.DataBind();

//左连接
            var leftJoin = from stu in db.Student
                           join sc in db.StuCourse
                           on stu.Sno equals sc.Sno
                           into temp
                           from t in temp.DefaultIfEmpty()
                           select new { stu.Sno, stu.Sage, Cid = t == null ? 0 : t.Cid };

//右连接
            var right = from sc in db.StuCourse
                        join stu in db.Student
                        on sc.Sno equals stu.Sno
                        into temp
                        from tt in temp.DefaultIfEmpty()
                        select new { sc.Cid, sc.Sno, SName = tt == null ? "" : tt.Sname };

//5、标准运算符之分组——GroupBy
             //按照年龄分组
            var stu6 = db.Student.GroupBy<Student, int>(s => (int)s.Sage);
            List<IGrouping<int, Student>> list2 = stu6.ToList();
            foreach (IGrouping<int,Student> item in list2)
            {
                //输出 小组 的 分组条件
                Response.Write(string.Format("小组:{0}<br/>",item.Key));
                //遍历 小组里 所有的 元素
                foreach (Student st in item)
                {
                    Response.Write(string.Format("姓名:{0}", st.Sname));
                }
                Response.Write("<br/>");
            }

//6、标准运算符之分页数据——Skip + Take
            //假设每页有5条记录
            //  int pageSize = 2;
            //return list.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();
            var pageOne = db.Student.Skip<Student>(24).Take(6);
            GridView1.DataSource = pageOne;
            GridView1.DataBind();

#endregion

附加:

int[] numbers = { 0, 30, 15, 90, 85, 40, 75,20, };
            int[] arr = { };
            int first = numbers.First<int>(m => m > 35); // 返回满足条件的第一条记录 90
            int last = numbers.Last<int>(n => n < 40);  //返回满足条件的最后一条记录 20
            bool allResult = numbers.All<int>(mm => mm < 100); //判断所有元素是否都满足  true
            bool allResult2 = numbers.All<int>(mm => mm>5); // false
            bool anyResult = numbers.Any(); //numbers中有元素 就返回 true
            bool anyResult1 = arr.Any();    //arr中没有元素 返回false
            bool anyResult2 = numbers.Any<int>(mm => mm <1);  // 只要有一个元素满足条件 就返回true
            bool anyResult3 = numbers.Any<int>(mm => mm >89); //true
            bool anyResult5 = numbers.Any(m => m > 200); //false

Linq使用之标准运算符方法的更多相关文章

  1. SQO (标准查询运算符)方法 & Linq To Object

    #region SQO (标准查询运算符) 方法 #region Where() Find() FindAll() FirstOrDefault()等方法 static void c01where() ...

  2. 《Entity Framework 6 Recipes》中文翻译系列 (26) ------ 第五章 加载实体和导航属性之延缓加载关联实体和在别的LINQ查询操作中使用Include()方法

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-7  在别的LINQ查询操作中使用Include()方法 问题 你有一个LINQ ...

  3. mvc ef LINQ to Entities 不识别方法“Int32 Parse(System.String)”,因此该方法无法转换为存储表达式。

    private sys_User GetUserInfo() { sys_User model = null; var userId = Convert.ToInt32(AccountHelper.G ...

  4. LINQ to Entities不识别方法***,因此该方法无法转换为存储表达式

    我的程序里有这么一段代码: order.OrderExpressInfo = (from oei in orderExpressRepository.Entities where oei.OrderI ...

  5. LINQ to Entities 不识别方法“System.String ToString()”,因此该方法无法转换为存储表达式。

    var data = DataSource.Skip(iDisplayStart).Take(iDisplayLength).Select(o => new { MatNR = o.MatNR, ...

  6. Linq中字段数据类型转换问题(Linq to entity,LINQ to Entities 不识别方法"System.String ToString()"问题解决)

    1.在工作中碰到这样一个问题: 使用linq时,需要查询两个表,在这两张表中关联字段分别是int,和varchar()也就是string,在linq中对这两个字段进行关联, 如果强制类型转换两个不同类 ...

  7. [置顶] IOS7状态栏StatusBar官方标准适配方法

    IOS7状态栏StatusBar官方标准适配方法 hello,大家好,ios7正式版已经发布,相信大家都在以各种方式来适配ios7. 如果你已经下载了xcode5,正准备使用,你会发现各种布局的改变. ...

  8. Linq to Entities不识别方法

    db.UserValidates.Include(a => a.User).Where(uv => u.UserValidates.Contains(uv, c)).ToList(); 执 ...

  9. LINQ to Entities 不识别方法“System.DateTime AddDays(Double)

    今天本想在linq里按照时间筛选一下超时的数据,一共两个字段FeedBackTime(计划反馈时间).EndTime(实际反馈时间).需求是这样的,查找数据库里所有EndTime大于FeedBackT ...

随机推荐

  1. Fetching android sdk component information

    原文地址: Android Studio安装以及Fetching android sdk component information超时的解决方案 - sonyi - 博客园 http://www.c ...

  2. linux进程模型总结

    Linux进程通过一个task_struct结构体描述,在linux/sched.h中定义,通过理解该结构,可更清楚的理解linux进程模型.       包含进程所有信息的task_struct数据 ...

  3. cookie分析

    浏览器cookie分析 简单点说就是数据存储,通过JavaScript将要保存的数据保存在客户端浏览器,下次打开网页时调用保存的cookie.浏览器中cookie保存的形式:user=aa; pwd= ...

  4. 使用SecureCRT上传和下载文件

    SecureCR 下的文件传输协议有ASCII .Xmodem .Ymodem .Zmodem.ASCII:这是最快的传输协议,但只能传送文本文件.Xmodem:这种传输协议速度较慢,但由于使用了CR ...

  5. nf_contrack_netlink.c

    /* Connection tracking via netlink socket. Allows for user space * protocol helpers and general trou ...

  6. 1470. UFOs(三维树状数组)

    1470 最简单的三维树状数组 #include <iostream> #include<cstdio> #include<cstring> #include< ...

  7. oralce索引和分区索引的使用

    oracle分区表和分区索引的本质就是将数据分段存储,包括表和索引(索引从本质上来讲也是表),表分区会将表分成多个段分别存储.由此数据查询过程改变为先根据查询条件定位分区表,然后从该表中查询数据,从而 ...

  8. bzoj1003: [ZJOI2006]物流运输

    dp+最短路.暴力枚举就可以了.O(n3logn).样例中m=n然后测样例过了.然后 54行习惯性的dis[n]然后就WA了!!!. #include<cstdio> #include&l ...

  9. [HDU 4828] Grids

    Grids Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Subm ...

  10. 使用Zxing实现扫二维码描

    1.集成Zxing.bar 2.复制代码到项目中 3.修改 MipacActivityCapture.java  的扫描结果方法 handleDecode() /** * 处理扫描结果,实现活动页面跳 ...