谈到dlinq ,就不得不先说linq 。让我们先看看什么是linq 。linq 是 Language Integrated Query 的缩写。那么事实上dlinq 就是 Database Language Integrated Query 的缩写。linq 和dlinq 最大的区别就在与linq 是对内存进行操作,而dlinq 的操作对象为数据库。
我们先来看一个linq 的例子。在这之前,你需要安装s2008 beta 2版本。可以到
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://www.my400800.cn
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 的说明文档上得到。
using System; using System.Query; using System.Collections.Generic; class app { static void Main() { string[] webSitenames = { "http://www.google.cn", "http://www.baidu.com", "http://www.my400800.cn", "http://www.sina.com.cn", "http://www.yahoo.com", "http://www.bing.com", "http://www.sogou.com", "http://www.soso.com" }; IEnumerable<string> expr = from s in webSitenames where s.Length == 22 orderby s select s.ToUpper(); foreach (string item in expr) Console.WriteLine(item); } }
你可能感觉比较陌生。放心,这大概是第一次看到缘故。在这里像 from ,where ,orderby, select 等都是linq 的保留字,都该用蓝色显示的,但是好像cnblogs 还没有开始支持。所以插入代码时,他们就被当作普通字符了。
其实,query expression 看起来和sql 语句很像。 比如 select * from table1 where column1 = "";
我第一次看到linq 时,就感觉是写在程序里的sql 语句。只不过,以前我们都是用string 类型形成一个sql 语句,然后通过command 或adapter 传到sql server 中。而现在,感觉就像把sql 语句直接当成程序代码来实现。这只不过是我们的一个错觉。
这个例子,只不过是从一个string 的数组中,提取出长度为22 的,并且把提取的数据全部变成大写。 IEnumerable <string > 使用到了c#2.0 中的泛型。 该列子的结果,返回一个数据集,存放到expr 中。 在这里,从那个数据集中取的结果,是用in 表达的,如列所示, from s in webSitenames , 在webSitenames 集合中,取出s 。s 代表一条条纪录。where 表示条件,orderby 表示按什么排序。select 选择那些字段组成变量。这里,你可能会觉得奇怪,s 变量在那里声明的呢。我第一看到这里的时候,也感到奇怪。其实s 变量是webSitenames 变量里的元素,你在in webSitenames 时,已经声明了s 变量。
在这个列子中,大家可以先感受一下linq ,在随后的章节中,我会为大家介绍更多。对内存数组的查询,并不能显示出linq 的强大功能,对数据库的操作,才使得linq 更加具有实际意义。 在随后的章节中,我将逐渐介绍dlinq 的语法。