LinQ

1、将非泛型转换为泛型的方法:

ArrayList lists =new ArrayList();   

 IEnumberable<T> myTEnum= lists .OfType<T>();

 

 ArrayList lists = new ArrayList();
         lists.AddRange(new object[]{1,"a",new object(),false});
          IEnumerable<int> myInts=lists.OfType<int>();
          foreach(int i in myInts)
          {
              Console.Write(i.ToString());
          }
          Console.ReadLine();

 

2、怎样延缓执行

var subset=from c in myCars where c.speed>5 select c;

  使用Sequence的ToArray<>()方法和ToList<>()方法可以提取集合的固定数据副本。

3、Sequence类的 Reverse<>()方法

         var subset=(from c in myCars select c).Reverse<Car>();
         将IEnumrable的值逆转循环

4、Sequence类的Distinct<T>()方法,用于排除重复对象

5、获取子集的特殊形式

  var subset=from c in mycars select new{c.Make,c.color};

6、建立查询表达式的方式,探索Linq底层原理

       1、Sequnce和Lambda

             int[] sStrs = new int[] { 1, 2, 3, 4, 5, 6 };
             var subset=sStr.Where(g=>g>1).OrderBy(g=>g).Select(g=>g);

         2、Sequence和匿名方法建立

                 //使用匿名方法建立Fun<>代理

                    int[] sStrs = new int[] { 1, 2, 3, 4, 5, 6 };
          Func<string, bool> searchFilter = delegate(string g) { return g > 1; };
          Func<string, string> itemToProcess = delegate(string s) { return s; };
          var subset = sStrs.Where(searchFilter).OrderBy(itemToProcess).Select(itemToProcess);

         3、Sequnce和原始代理

           //代理目标
      public static bool Filter(string s) { return s.Length > 1; }
      public static string ProcessItem(string s) { return s; }
      private void AnonymousOriginal()
      {
          int[] sStrs = new int[] { 1, 2, 3, 4, 5, 6 };
          //Fun<>代理
          Func<string, bool> searchFilter = new Func<string, bool>(Filter);
          Func<string, string> itemProcess = new Func<string, string>(ProcessItem);
          var subset = sStrs.Where(searchFilter).GroupBy(itemProcess).Select(itemProcess);
      }

7、 foreach(var car in from c in sStrs select c)

 

8、特性 Table Column

  [Table(name="tab")] public string sT;

 [Column(id=true)] public int id;

9、生成Linq类的工具  sqlmetal.exe

           

06-26
### LINQ 技术文档与使用指南概述 LINQ(Language Integrated Query)是 C# 中一种强大的查询语言,允许开发者以统一的方式处理各种数据源,如集合、数据库和 XML 文档。它通过集成在 C# 语言中的语法,简化了传统查询操作,并提升了代码的可读性和可维护性。 #### 查询语法 LINQ 提供了两种主要的查询语法形式:**查询表达式语法** 和 **方法语法**。查询表达式语法更接近 SQL 风格,适合编写复杂的查询逻辑;而方法语法则基于 Lambda 表达式,适用于简洁的操作链式调用。 以下是一个使用查询表达式语法的示例: ```csharp var filteredData = from item in dataList where item.Value > 10 select item; ``` 该代码从 `dataList` 中筛选出值大于 10 的元素,并将结果存储到 `filteredData` 中。 相比之下,使用方法语法的等效代码如下: ```csharp var filteredData = dataList.Where(item => item.Value > 10); ``` #### 延迟执行与立即执行 LINQ 查询分为**延迟执行**和**立即执行**两种模式。延迟执行意味着查询的实际执行会推迟到遍历结果时进行,这种方式可以提高性能,特别是在处理大型数据集时。例如: ```csharp var query = from item in dataList where item.IsActive select item; ``` 只有在对 `query` 进行迭代时,如使用 `foreach` 循环,查询才会实际执行。 另一方面,立即执行是指查询在定义后立即执行并返回结果。常见的立即执行操作包括 `ToList()` 和 `ToArray()` 等聚合函数: ```csharp var activeItems = (from item in dataList where item.IsActive select item).ToList(); ``` 上述代码中,`ToList()` 触发了查询的立即执行,并将结果存储为一个列表。 #### 性能优化建议 尽管 LINQ 提供了便捷的查询方式,但在处理大规模数据时需要注意性能问题。以下是几个优化技巧: - **避免不必要的多次枚举**:某些操作可能导致查询被多次执行,增加开销。可以通过缓存中间结果来减少重复计算。 - **选择合适的数据结构**:根据需求选择合适的集合类型,如使用 `HashSet<T>` 实现快速查找。 - **合理使用 `AsEnumerable()` 和 `AsQueryable()`**:在需要切换 LINQ 提供程序时,明确指定执行环境,避免意外行为 [^1]。 #### 数据源支持 LINQ 支持多种数据源的查询操作,包括但不限于: - **内存中的集合**:通过 `System.Linq.Enumerable` 类实现,适用于数组、列表等本地数据。 - **数据库**:借助 Entity Framework 等 ORM 框架,LINQ 可以直接用于数据库查询。 - **XML 文档**:通过 `System.Xml.Linq` 命名空间提供的类,LINQ 能够高效解析和操作 XML 数据。 例如,查询 XML 文档的代码可能如下: ```csharp XDocument doc = XDocument.Load("data.xml"); var elements = from element in doc.Descendants("Item") where (int)element.Element("Value") > 10 select element; ``` #### 扩展性与自定义查询提供程序 LINQ 的设计具有高度扩展性,开发者可以创建自定义的查询提供程序,以便在特定数据源上实现 LINQ 查询功能。这通常涉及实现 `IQueryable` 和 `IQueryProvider` 接口,并定义相关的表达式树解析逻辑。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值