C# 3.0 入门系列(一)

原文地址为: C# 3.0 入门系列(一)

谈到dlinq,就不得不先说linq。让我们先看看什么是linq。linq是 Language Integrated Query的缩写。那么事实上dlinq就是 Database Language Integrated Query 的缩写。linq和dlinq最大的区别就在与linq是对内存进行操作,而dlinq的操作对象为数据库。
我们先来看一个linq的例子。在这之前,你需要安装s2008 beta2版本。可以到
  http://msdn2.microsoft.com/en-us/vstudio/aa700831.aspx 下载。如果,你的机器上是vs2005的英文版,你还需要安装一个linq preview版本。你可以到下面地址去下载。
http://www.microsoft.com/downloads/details.aspx?familyid=1e902c21-340c-4d13-9f04-70eb5e3dceea&displaylang=en
微软也提供了好多学习的地方。先给出几个链结。
http://msdn.microsoft.com/data/ref/linq/
http://msdn.microsoft.com/data/ref/linq/default.aspx?pull=/library/en-us/dndotnet/html/linqprojectovw.asp
http://msdn.microsoft.com/vcsharp/future/

好,我们先来看一个linq的例子。这个例子可以从linq的说明文档上得到。
9310e85a14af99de4811ff4c77f1f911.jpe 24a924a57ba6b3f2b51fc9edb7ea4186.jpe the linq sample
 1731655954c7be9d8835ece551b5385f8.jpeusing System;
 2731655954c7be9d8835ece551b5385f8.jpeusing System.Query;
 3731655954c7be9d8835ece551b5385f8.jpeusing System.Collections.Generic;
 4731655954c7be9d8835ece551b5385f8.jpe
 524a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpeclass app 222530190136c9c4cfd237cc0d5cff99.jpe{
 6715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe  static void Main() 222530190136c9c4cfd237cc0d5cff99.jpe{
 7715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe    string[] names = 222530190136c9c4cfd237cc0d5cff99.jpe"Burke""Connor""Frank"
 81408c5260b2f05e450dee929db9be5f7.jpe                       "Everett""Albert""George"
 95bcb1807ee3e00d2b3c225f0b3f5c751.jpe                       "Harris""David" }
;
101408c5260b2f05e450dee929db9be5f7.jpe
111408c5260b2f05e450dee929db9be5f7.jpe    IEnumerable<string> expr = from s in names 
121408c5260b2f05e450dee929db9be5f7.jpe                               where s.Length == 5
131408c5260b2f05e450dee929db9be5f7.jpe                               orderby s
141408c5260b2f05e450dee929db9be5f7.jpe                               select s.ToUpper();
151408c5260b2f05e450dee929db9be5f7.jpe
161408c5260b2f05e450dee929db9be5f7.jpe    foreach (string item in expr)
171408c5260b2f05e450dee929db9be5f7.jpe      Console.WriteLine(item);
185bcb1807ee3e00d2b3c225f0b3f5c751.jpe  }

19f466905a3bcb5dcef110eab799825254.jpe}

20731655954c7be9d8835ece551b5385f8.jpe

你可能感觉比较陌生。放心,这大概是第一次看到缘故。在这里像 from ,where,orderby, select等都是linq的保留字,都该用蓝色显示的,但是好像cnblogs还没有开始支持。所以插入代码时,他们就被当作普通字符了。

其实,query expression看起来和sql语句很像。 比如 select * from table1 where column1 = "";
我第一次看到linq时,就感觉是写在程序里的sql语句。只不过,以前我们都是用string类型形成一个sql语句,然后通过command或adapter传到sql server中。而现在,感觉就像把sql语句直接当成程序代码来实现。这只不过是我们的一个错觉。

这个例子,只不过是从一个string的数组中,提取出长度为5的,并且把提取的数据全部变成大写。 IEnumerable <string> 使用到了c#2.0中的泛型。 该列子的结果,返回一个数据集,存放到expr中。 在这里,从那个数据集中取的结果,是用in 表达的,如列所示, from s in names , 在names集合中,取出s。s代表一条条纪录。where 表示条件,orderby 表示按什么排序。select 选择那些字段组成变量。这里,你可能会觉得奇怪,s变量在那里声明的呢。我第一看到这里的时候,也感到奇怪。其实s变量是names变量里的元素,你在in names 时,已经声明了s变量。

在这个列子中,大家可以先感受一下linq,在随后的章节中,我会为大家介绍更多。对内存数组的查询,并不能显示出linq的强大功能,对数据库的操作,才使得linq更加具有实际意义。
在随后的章节中,我将逐渐介绍dlinq的语法。
http://www.cnblogs.com/126/archive/2006/08/14/476800.html
转载请注明本文地址: C# 3.0 入门系列(一)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值