2.2 LINQ中使用from子句指定数据源

时间:2023-03-10 01:03:22
2.2 LINQ中使用from子句指定数据源

  数据源是LINQ查询中必不可少的元素,数据源是实现泛型接口IEnumerable<T>或IQueryable<T>的类对象。

  可以将IEnumerable<T>简单理解成一个包含多个元素的列表(或数据库中的表),可以用foreach遍历它所有的元素,从而轻松地完成查询操作。

  由于是泛型接口,所以通过为数据源指定不同的元素类型,可以表示任何数据集合。

  在.NET类库中,列表类、集合类、数组等都实现了接口IEnumerable<T>,所以可以直接将这些数据对象作为数据源在LINQ查询中使用。

  每个LINQ查询都以from子句开始,from子句包括以下两个功能:

  • 指定查询将采用的数据源
  • 定义一个本地变量,表示数据源中的单个元素

  单个from子句的编写格式如下,其中,dataSource表示数据源,localVal表示单个元素:

 from localVal
 select dataSource

  一般情况下,不用为from子句的localVal元素指定数据类型,编译器会根据数据源的类型为它分配合适的类型,通常元素类型为IEnumerable<T>中的类型T。

  例如,当数据源为IEnumerable<int>时,编译器为localVal指定类型为int。当数据远为IEnumerable<string>时,编译器为localVal指定类型为string。

  如下列代码所示,由于nums是int[]类型,默认实现了接口IEnumerable<int>,所以numItem的类型为int:

 ,,,,,,,}; // 定义int数组nums为数据源
 var queryResult = (from numItem in nums select numItem); // LINQ查询数据源nums中所有元素

  一些特殊情况下,开发人员还需要为本地变量指定数据类型,比如上面的代码,希望将nums中的元素作为object类型进行处理,而不是作为int。这就需要在form子句中为numItem指定目标类型。

  如下列代码所示,指定numItem为object类型,由于nums中的元素为int类型,属于object类型的子类型,所以可以直接转换为object类型:

 ,,,,,,,}; // 定义int数组nums为数据源
 var queryResult = (from object numItem in nums select numItem); // LINQ查询数据源nums中所有元素,指定元素类型为object

  值得一提的是,编译器并不会检查本地变量(numItem元素)的具体类型,所以当指定类型不正确时,编译时并不会报错。

  如下面的代码,本地参数numItem指定为Student类型,但是numItem实际是int类型,所以将numItem指定为Student类型是错误的,编译器并不会报错。

  但是当下面的foreach语句使用该查询时,会在运行时进行类型检查,从而产生异常。

     class Program
     {
         static void Main(string[] args)
         {
             , , , , , , ,  };    // 定义int数组nums为数据源
             var queryResult = (from Student numItem in nums select numItem);    // LINQ查询数据源nums中所有元素,元素类型指定为Student
             // 遍历并打印查询结果
             foreach (var item in queryResult)
             {
                 Console.Write(item.ToString());
             }
         }
     }

     class Student { }

  当Debug上面代码的时候,产生的异常提示如下图,即不能将一个int类型的变量强制转换成Student类型:

2.2 LINQ中使用from子句指定数据源

建议:如果没有特别需要,笔者建议使用不指定类型的本地变量,让编译器自动根据数据源判断具体的元素类型。

内容参考:

《精通C#5.0与.NET 4.5高级编程——LINQ、WCF、WPF和WF》

【来自 孤影'Blog:http://www.cnblogs.com/LonelyShadow,码字不容易,转载请注明出处。】