• LinQ使用积累


    1. 用Linq查询datatable中的行是否重复
    intcount1 = (from p indt.AsEnumerable() select p).Distinct().Count();
    intcount2 = (from p indt.AsEnumerable() select p).Count();
    if(count1 < count2)
    {
      MessageBox.Show("重复");
    }

    2. 用Linq查询List中的行是否重复
    List<int> Numbers = newList<int> { 1, 2, 3, 7, 31 };
    Console.WriteLine(Numbers.Distinct().Count() == Numbers.Count);
    Console.ReadKey();

    3. 用Linq查找重复值的方法
    Dictionary plants = new Dictionary() {
      {1,"Speckled Alder"},
      {2,"Apple of Sodom"},
      {3,"Hairy Bittercress"},
      {4,"Pennsylvania Blackberry"},
      {5,"Apple of Sodom"},
      {6,"Water Birch"},
      {7,"Meadow Cabbage"},
      {8,"Water Birch"}
    };
    //find dictionary duplicate values.
    var duplicateValues = plants.GroupBy(x => x.Value).Where(x => x.Count() > 1);

    4. 用Linq根据需要重组新的实体并输出
    A. 使用单一对象列表重组新的对象列表:
    var srcObjectList = 原本实例对象列表.ToList()
    var newObjectList = from a in srcObjectList select new  //new是创建新的对象,十分重要。
    {
      新对象成员1 = srcObjectList.属性1,
      新对象成员2 = srcObjectList.属性2,
      新对象成员3 = srcObjectList.属性3,
      新对象成员4 = srcObjectList.属性4,
      新对象成员5 = srcObjectList.属性2 + srcObjectList.属性3
    }
    新对象列表(newObjectList)使用旧对象列表(srcObjectList)的部分属性,重组成新的对象列表。

    B. 使用两个不同对象列表属性重组新的对象列表:
    var srcObjectList1 = 原本实例对象列表1.ToList()
    var srcObjectList2 = 原本实例对象列表2.ToList()
    var newObjectList = from a in srcObjectList1 join b in srcObjectList2 on a.属性 equals b.属性 select new  //new是创建新的对象,十分重要。

    {
      新对象成员1 = a.属性1,
      新对象成员2 = b.属性2,
      新对象成员3 = a.属性2,
      新对象成员4 = b.属性3,
      新对象成员5 = b.属性4,
      新对象成员6 = a.属性3,
      新对象成员7 = a.属性4 + b.属性1
    }
    新对象列表(newObjectList)使用两个旧对象列表(srcObjectList1、srcObjectList2)的部分属性,重组成新的对象列表。

  • 相关阅读:
    MySQL5.7 多实例
    千万不要去考验人性
    Mysql事件监控日志
    chmod a+r file:给所有用户添加读的权限
    percona-toolkit 之 【pt-summary】、【pt-mysql-summary】、【pt-config-diff】、【pt-variable-advisor】说明
    腾讯游戏DBA团队的发展自白
    致DBA:为什么你经常犯错,是因为你做的功课不够
    这套方法论,彻底终结MySQL同步延迟问题
    gh-ost:不一样的在线表结构变更
    初试GH-OST(转)
  • 原文地址:https://www.cnblogs.com/MatrixBlogs/p/7211842.html
Copyright © 2020-2023  润新知