LINQ 查询基于泛型类型,在 .NET Framework 的 2.0 版中引入了泛型类型。您无需深入了解泛型即可开始编写查询。在此,您可能需要了解两个基本概念:
1. 当您创建泛型集合类(如 List<T>)的实例时,您将“T”替换为列表将包含的对象的类型。例如,字符串列表表示为 List<string>,Customer 对象列表表示为 List<Customer>。泛型列表是强类型的,且提供了比将其元素存储为 Object 的集合更多的好处。如果您尝试将 Customer 添加到 List<string>,则会在编译时出现一条错误。泛型集合易于使用的原因是您不必执行运行时类型强制转换。
2. IEnumerable<T> 是一个接口,通过该接口,可以使用 foreach 语句来枚举泛型集合类。泛型集合类支持 IEnumerable<T>,就像非泛型集合类(如 ArrayList)支持 IEnumerable。
下面我们通过几个例子来看看linq是如何利用泛型对数据进行操作的。
实例一:
int[] number = new int[] { 1, 3, 2, 4, 5, 6, 7 };
var n = from nb in number where (nb > 3) select nb;
foreach (var i in n)
{
Response.Write(i);
}
输出的结果是:4567.
实例二:
我们需要建一个实体类person.cs
public class person
{
public string name
{ get; set; }
public int age
{ get; set; }
public string sex
{ get; set; }
}
接下来我们在页面上运行如下代码
List<person> plist = new List<person>();
person per = new person();
plist.Add(new person { name = "cxx1", age = 24, sex = "男" });
plist.Add(new person { name = "cxx2", age = 25, sex = "男" });
plist.Add(new person { name = "cxx3", age = 26, sex = "男" });
var selectperson = from person p in plist select p;
GridView1.DataSource = selectperson;
GridView1.DataBind();
在这里我们估计会有一个疑问,就是如果我需要按条件查询的话,应该怎么处理,LINQ也和SQL类似,提供了where的查询条件。
我们来修改下上面List<person>集合的代码,我们这里要查询年龄为24的数据:
var selectperson = from person p in plist where (p.age.Equals(24)) select p;