linq to sql 学习(3)LINQ 和泛型类型

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;

     

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值