一、环境搭建

下面将逐步搭建我们学习的环境,这个环境不仅仅是这次需要使用,以后的教程一样需要使用这个环境。所以请大家务必按照

搭建这里的环境否则会影响你后面的学习。

  1. 我们用到的几张表

    通知消息表:

    用户表:

  2. 在VS中生成表

    2.1  新建一个控制台程序(略)

    2.2  新建一个Linq To Sql类

    2.3 新建数据连接

    2.4 添加连接

    2.5 映射表

    环境到此已经设置完毕,后面我们将开始正式的学习

二、操作符学习

  1. 投影操作符

    简单点说就是更SQL语句中的 AS 操作符一个意思,就是把列名换掉。但是我们这里的投影远比SQL语句中的AS
    拥有更强大的地方。

    1.1.1 下面是一个简单的投影使用

             static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = from item in dc.Db_SST_Notic
    select new { NID = item.NoticID, NTitle = item.NoticTitle };
    //这里使用 new 将 NoticID 的列名改为 NID,将 NoticTitle 的列名改为 NTitle
    //最后的result就会
    foreach (var item in result)
    {
    System.Console.WriteLine(" ID = {0}; Title = {1} ", item.NID, item.NTitle);
    }
    System.Console.ReadKey();
    }

    1.1.2 最后遍历result的时候,item中除了集成自Object的基本方法以外,就是投影的属性名如图:

    1.1.3 这是最后的结果(数据根本个人情况会不一样)

    1.2.1 下面来演示一个较复杂的

             //新建的一个数据模型
    class Modal
    {
    public int NID { get; set; }
    public String NTitle { get; set; }
    } static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    //将最终结果投影成我们自己数据模型
    IEnumerable<Modal> result = from item in dc.Db_SST_Notic
    select new Modal()
    {
    NID = item.NoticID,
    NTitle = item.NoticTitle
    };
    //这里使用 new 将 NoticID 的列名改为 NID,将 NoticTitle 的列名改为 NTitle
    //最后的result就会
    foreach (var item in result)
    {
    System.Console.WriteLine(" ID = {0}; Title = {1} ", item.NID, item.NTitle);
    }
    System.Console.ReadKey();
    }

    其中我们新建了一个数据模型,然后使用投影,将最终的数据投影成我们新建的数据模型,最终的结果更上面的结果一样。

  2. 限制操作符

    简单说就是SQL语句中的where,就是用来对数据进行筛选。

    2.1 下面是一个用来获得重要通知的语法

             static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    //将最终结果投影成我们自己数据模型
    var result = from item in dc.Db_SST_Notic
    where item.IsMust.Value
    select new
    {
    NID = item.NoticID,
    NTitle = item.NoticTitle
    };
    foreach (var item in result)
    {
    System.Console.WriteLine(" ID = {0}; Title = {1} ", item.NID, item.NTitle);
    }
    System.Console.ReadKey();
    }

    其中的 where item.IsMust.Value 就是用来将重要的通知从中筛选出来

    2.2 下面是最终的结果

  3. 排序操作符

    等同于SQL语句中的orderby

    3.1 下面是一个按通知ID逆序,并且按发送时间正序的语法

             static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = from item in dc.Db_SST_Notic
    where item.IsMust.Value
    orderby item.NoticID descending,item.SendTime
    select new
    {
    NID = item.NoticID,
    NTitle = item.NoticTitle
    };
    foreach (var item in result)
    {
    System.Console.WriteLine(" ID = {0}; Title = {1} ", item.NID, item.NTitle);
    }
    System.Console.ReadKey();
    }

    通过上面的 orderby item.NoticID descending,item.SendTime 就可以将数据进行排序

    3.2 下面是结果

  4. 联接操作符

    等同于SQL语句中的inner join

    4.1 下面是一个将通知表与用户表进行关联的语句

             static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = from item in dc.Db_SST_Notic
    join user in dc.Sys_SST_User on item.SendNoticUserID equals user.UserID
    where item.IsMust.Value
    orderby item.NoticID descending, item.SendTime
    select new
    {
    NID = item.NoticID,
    NTitle = item.NoticTitle,
    User = user.UserName
    };
    foreach (var item in result)
    {
    System.Console.WriteLine(" ID = {0}; Title = {1}; User = {2} ", item.NID, item.NTitle,item.User);
    }
    System.Console.ReadKey();
    }

    其中join 后面跟着的 user in dc.Sys_SST_User 就是获取用户表的集合,后面的 on item.SendNoticUserID equals user.UserID 就是关联
    的条件,这样就可以将用于表与通知表进行关联了,然后注意最后的投影,我们多了一个 User = user.UserName 这样我们就可以在最后的结果
    中看到发送该通知的用户。

    4.2 下面是最后的结果

  5. 特殊的联接操作符

    这个操作符可以用来获取两张存在一对多的关系的数据,比如这里用户可以对应多条通知,假如我们需要显示每个用户发送的通知,以一种
    父子的关系来呈现,我们可以用以下的语句来实现。

    5.1

             static void Main(string[] args)
    {
    LinqDataDataContext dc = new LinqDataDataContext();
    //var result = from item in dc.Db_SST_Notic
    // join user in dc.Sys_SST_User on item.SendNoticUserID equals user.UserID
    // where item.IsMust.Value
    // orderby item.NoticID descending, item.SendTime
    // select new
    // {
    // NID = item.NoticID,
    // NTitle = item.NoticTitle,
    // User = user.UserName
    // };
    var result = dc.Sys_SST_User.GroupJoin(dc.Db_SST_Notic, user => user.UserID, notic => notic.SendNoticUserID, (user, notic) =>
    new { UserID = user.UserID, Name = user.UserName, notics = notic.Select(n => n.NoticTitle) });
    foreach (var item in result)
    {
    System.Console.WriteLine(" UserID = {0} ; Name = {1} ", item.UserID,item.Name);
    foreach (string subitem in item.notics)
    {
    System.Console.WriteLine(" Title = {0} ", subitem);
    }
    }
    System.Console.ReadKey();
    }

    其中 GroupJoin 的第一个参数是需要联接的表,第二个参数是 Sys_SST_User 的条件字段(用来和第三个参数进行对比),第三个参数是
    第一个参数表中的条件字段(用来与第二个参数进行对比),最后的参数就是在将两个表中的条件进行对比后的结果,其中user参数表示一个
    用户数据,而notic表示的是多个通知,这里我们就可以使用投影来获取我们需要的数据。

    5.2 下面是最终的结果(我可截取了存在通知的用户)

    这里可以看到最终的结果,就是一种从属的关系。

  6. 聚合操作符

    聚合操作符基本都是SQL语句中的MAX、MIN、COUNT、AVERAGE等

    6.1 Aggregate操作符

    它的功能就是将上一次的结算结果作为执行函数的第一个参数,将当前处理的数据作为第二个参数,并且把返回的参数作为
         下一个执行方法的第一个参数。
         
         6.1.1 下面是一个累加的实现

                 int[] s = new int[] { , , , , , , , ,  };
    var result = (from item in s
    select item).Aggregate(
    (ct, nt) => { return ct + nt; });
    System.Console.WriteLine(" NIDADD = {0} ", result);

    这里我要说明一下,为什么我们这里是对一个数组的数据进行操作,而不是之前对一个集合,因为集合是不支持单一的循环的
    当然你在SQL语句中可能用过游标,而游标的实现方式就是面对行而不是集合。

    6.1.2 下面是结果

    6.2 Average操作符

    它的功能就是求结果的平均值

    6.2.1 下面我们举一个求通知ID的平均值

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.NoticID).Average();
    System.Console.WriteLine(" Average is {0}", result);

    6.2.2 下面是最终的结果

    6.3 Count操作符

    它的功能就是求结束的数量

    6.3.1 下面是输出通知的总数

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.NoticID).Count();
    System.Console.WriteLine(" Count is {0}", result);

    6.3.2 下面是最终结果

    提示下Count操作符只能返回不超过Int32能够表示的数量范围。如果数据量会超过Int32所能表示的范围,可以使用下面
    介绍的操作符。

    6.4 LongCount操作符

    6.4.1 下面是输出通知的总数

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.NoticID).LongCount();
    System.Console.WriteLine(" Count is {0}", result);

    6.4.2 最终结果同上

    6.5 Max操作符
               它的功能就是求结果数据中最大的一条数据

    6.5.1 下面是求通知ID中的最大ID

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.NoticID).Max();
    System.Console.WriteLine(" Count is {0}", result);

    6.5.2 下面是最终结果

    6.6 Min操作符
              它的功能就是求结果数据中最小的一条数据

    6.6.1 下面是输出通知ID中最小的ID

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.NoticID).Min();
    System.Console.WriteLine(" Max is {0}", result);

    6.6.2 下面是最终结果

  7. 集合操作符

    7.1 Distinct操作符
                 用于去除结果中重复的值

    7.1.1 下面是用来获取已经发送通知的用户ID
                       用于通知可以由一个用户发送多个,所以直接搜索就会出现重复。

                 LinqDataDataContext dc = new LinqDataDataContext();
    var result = (from item in dc.Db_SST_Notic
    select item.SendNoticUserID).Distinct();
    foreach (var item in result)
    {
    System.Console.WriteLine(" UserID = {0} ", item.Value);
    }
    System.Console.ReadKey();

    7.1.2 下面最后的结果

    7.2 Union操作符
                 用于将两个结果集合并但是不会显示重复的数据
       
           7.2.1 下面我们新建两个数组然后进行合并

                 int[] i1 = new int[] {,, };
    int[] i2 = new int[] { , , , , , , };
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = i1.Union(i2);
    foreach (var item in result)
    {
    System.Console.WriteLine(" UserID = {0} ", item);
    }
    System.Console.ReadKey();

    7.2.2 下面是最终的结果

       7.3 Intersect操作符
                  用于返回两个集合中都存在的数据
          
          7.3.1 下面我们继续使用上面的数据然后改变为交集

                 int[] i1 = new int[] {,, };
    int[] i2 = new int[] { , , , , , , };
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = i1.Intersect(i2);
    foreach (var item in result)
    {
    System.Console.WriteLine(" UserID = {0} ", item);
    }
    System.Console.ReadKey();

    7.3.2 下面是最终的结果

      7.4 Except操作符
                   它的功能与Intersect操作符刚好相反,它是将在两个集合中没有同时存在的值返回

    7.4.1 下面我们继续使用上面的数据然后改变方式为差集

                 int[] i1 = new int[] {,, };
    int[] i2 = new int[] { , , , , , , };
    LinqDataDataContext dc = new LinqDataDataContext();
    var result = i2.Except(i1);
    foreach (var item in result)
    {
    System.Console.WriteLine(" UserID = {0} ", item);
    }
    System.Console.ReadKey();

    7.4.2 下面是最终结果
         

Linq学习之操作符的更多相关文章

  1. LINQ查询操作符 LINQ学习第二篇[转]

    一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...

  2. LINQ查询操作符 LINQ学习第二篇

    一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataCo ...

  3. Linq学习(一)

    与LINQ有关的语言特性 1.隐式类型 var 2.匿名类型 如:var obj = new {Guid.Empty, myTitle = "匿名类型", myOtherParam ...

  4. Linq学习工具及Lamada表达式

    好东西.转载一个.以备学习 Linq学习工具:     http://www.linqpad.net/ Lamada表达式: Func<int, int, int> IntPow = (x ...

  5. linq学习

    最全的linq学习文章: http://www.cnblogs.com/heyuquan/p/Linq-to-Objects.html

  6. (转)Linq学习笔记

    写在前面 最近在看Linq,在博客园看到这篇文章,写的通俗易懂,转来和大家一起做个分享.原文地址http://www.cnblogs.com/goscan/archive/2011/05/05/Lin ...

  7. LINQ标准查询操作符(三)——Aggregate、Average、Distinct、Except、Intersect、Union、Empty、DefaultIfEmpty、Range、Repeat

    七.聚合操作符 聚合函数将在序列上执行特定的计算,并返回单个值,如计算给定序列平均值.最大值等.共有7种LINQ聚合查询操作符:Aggregate.Average.Count.LongCount.Ma ...

  8. C#之Linq学习笔记【转】

    写在前面 其实在09年就已经学习过Linq了,并被她那优美的语法所吸引,只是现在所在的公司还在使用VS2005在.Net2.0的框架下面的开发,所以Linq也很久没有用过了,最近看部门的同事对这个有些 ...

  9. Linq 标准查询操作符三

    本文介绍了LINQ标准查询操作符.没有这些操作符,LINQ就不会存在.本文为理解这些操作符的功能提供了很好的基础.了解它们将会很有帮助,因为LINQ的各种Provider都是基于这些操作符来完成各自丰 ...

随机推荐

  1. JAVA的Random类[转]

    在实际的项目开发过程中,经常需要产生一些随机数值,例如网站登录中的校验数字等,或者需要以一定的几率实现某种效果,例如游戏程序中的物品掉落等. 在Java API中,在java.util包中专门提供了一 ...

  2. AX2009按照批次生产日期预留

    AX2009如果想按照批处理号预留,它默认是按照InventBatchId排序的,但并不是InventBatchd小的批次的生产日期就早,所以这个逻辑得改一下,让它按照InventBatch的Prod ...

  3. 为窗体设置背景图片-UI界面编辑器(SkinStudio)教程

    1.1.   为窗体设置背景图片 在窗体的Background属性中选择图片设置为窗体背景图片

  4. UVa 10071 - Back to High School Physics

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=94&page=s ...

  5. 8.springMVC中的RESTful架构风格

    RESTful架构:是一种设计的风格,并不是标准,只是提供了一组设计原则和约束条件,也是目前比较流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以正得到越来越多网站的采用. 关于 ...

  6. DIOCP之获取在线用户列表

    通过获取tcpserver.getonlinecontextlist来得到在线列表 procedure TfrmMain.btn_refreshClick(Sender: TObject);var l ...

  7. ibatis XML标签的含义

    selectKey: 有3个主要的属性:     1)resultClass:返回的主键的数据类型,跟sqlMap中的数据类型一致:     2)type:表示主键在insert之前或之后生成(取决于 ...

  8. Python_sklearn机器学习库学习笔记(一)_Feature Extraction and Preprocessing(特征提取与预处理)

    # Extracting features from categorical variables #Extracting features from categorical variables 独热编 ...

  9. [刘阳Java]_Java程序员的成长路线_第3讲

    按照Java从业人员的职位晋升来说,Java程序成长路线大致如下 Java程序员 JavaEE初级软件工程师 JavaEE中级软件工程师 JavaEE高级软件工程师 Java架构师 按照职业发展方向, ...

  10. JS事件冒泡

    JavaSciprt事件中有两个很重要的特性:事件冒泡以及目标元素. 事件冒泡: 当一个元素上的事件被触发的时候,比如说鼠标点击了一个按钮,同样的事件将会在那个元素的所有祖先元素中被触发.这 一过程被 ...