LINQ技术学习

系统 1961 0

LINQ是什么?
它是Language Integrated Query。
当我们要对数据库表进行查询的时候,我们一定会编写 "select * from sometable where ID = .."的语句。好,那我们现在根据LINQ的语法,完全可以将我们熟悉的SQL中像"select","from","where"等语句在.NET Framework环境中顺利使用并且大大提高开发的效率。

LINQ技术

LINQ集成到代号为Orcas的Visual Studio 2008中,而且LINQ包含了一些非常酷的框架和工具支持,包括完全的智能感知和可视化设计器支持。

LINQ系列技术,包括LINQ,DLINQ,XLINQ和不久后的其他技术。

LINQ、DLINQ、XLINQ
LINQ是Language Integrated Query的缩写。
DLINQ是Database Language Integrated Query 的缩写。
DLINQ是XML Language Integrated Query 的缩写,.NET Language Integrated Query for XML.

LINQ、DLINQ、XLINQ三者的最大区别是操作对象的不同。
LINQ和DLINQ最大的区别:LINQ是对内存进行操作,而DLINQ的操作对象为数据库。
LINQ、DLINQ、XLINQ,在微软的Visual Studio 2008(Visual Studio 2008下载请在ad0.cn找)中都已集成。


C#3.0中DLINQ从数据库获得数据集,XLINQ从XML文件获得数据集的方法

DLINQ 如何链接到数据库?
直接用DLINQ访问数据库,如何自己编码去链接数据库,这样我们才能对DLINQ链接数据库有更深入的了解。

DLINQ链接数据库代码:
获得 pubs 数据库 authors 表的所有作者的 au_id 信息。

程序代码
using System;
using System.Linq;
using System.Data.Linq; // 这个命名空间在单独的组件 System.Data.Linq.dll 中

public class DLinqTest
{
public static void DoSomeThing()
{
// 链接字符串
string connectionString = "Data Source=192.168.5.2;Initial Catalog=pubs;Persist Security Info=True;User ID=sa;Password=******";

// 通过使用 DataContext来DLINQ链接数据库的。
DataContext db = new DataContext(connectionString);
Table<Authors> authors = db.GetTable<Authors>();
var users = from a in authors orderby a.au_id select a;
foreach (var a in users)
{
Console.WriteLine(a.au_id);
}
}
}



// 数据库中的表结构影射的实体对象,注意其中的 Attribute.

程序代码
[Table(Name = "authors")]
public class Authors
{
[Column(IsPrimaryKey = true)]
public string au_id { get; set; }
[Column]
public string au_lname { get; set; }
[Column]
public string au_fname { get; set; }
[Column]
public string phone { get; set; }
[Column]
public string city { get; set; }
[Column]
public string state { get; set; }
[Column]
public string zip { get; set; }
[Column]
public bool contract { get; set; }
}



DLINQ链接到数据库的步骤

1、创建数据表跟实体对应的实体类(字段和元素可以不一一对应),并把这个类标上Table 特性,根数据表字段有关的元素标上Column特性;

2、使用 DataContext 和数据库链接字符串建立跟数据库的链接,然后使用 DataContext 的实例的 GetTable 方法获得对应表影射的实体类。


XLINQ访问XML文件的方法

XLINQ的例子,通过获得AD0.cn博客的RSS,然后把AD0.cn的RSS中的链接和标题打印出来:

XLINQ访问XML文件的演示代码:

程序代码
using System;
using System.Linq;
using System.Xml.Linq;

public class XLINQ
{
public static void DoSomeThing()
{
XElement feed = XElement.Load(" http://www.ad0.cn/netfetch/feed.asp ");
if (feed.Element("channel") == null)
return;

var rss = from item in feed.Element("channel").Elements("item")
select new
{
title = item.Element("title").Value,
link = item.Element("link").Value
};
foreach (var item in rss)
{
Console.WriteLine(item.link);
Console.WriteLine(item.title);
Console.WriteLine("*****");
}
}
}



XLINQ 加载数据的核心就在于XElement.Load。


Visual Studio 2008 Download
Visual Studio 2008下载
Visual Studio Team System 2008正式版下载

下面我就牛刀小试,做个demo看看。

1. 先下载LinQ框架
现在最新版本是2006年5月发布"Orcas CTP", 下载地址( 这里 )

2. 下载安装待完毕。

3. 新建一个"LINQ Console Application"项目。

4. 输入代码如下:

1
2 using System;
3 using System.Collections.Generic;
4 using System.Text;
5 using System.Query;
6 using System.Xml.XLinq;
7 using System.Data.DLinq;
8
9 namespace LINQConsoleApplication1
10 {
11 class Program
12 {
13 static void Main( string [] args)
14 {
15 string [] aBunchOfWords = { " One " , " Two " , " Hello " , " World " ,
16
17 " Four " , " Five " }
;
18 var result =
19 from s in aBunchOfWords // query the string array
20 where s.Length == 5 // for all words with length = 5
21 select s; // and return the string
22 foreach (var s in result) {
23 Console.WriteLine(s); // print
24 }

25 }

26 }

27 }

28
29


运行结果如下:
Hello
World
print any key to continue ...

这是我学习LINQ的第一个小程序,深感LINQ对编程语言带来的改变。将此例子给大家共同学习!

LINQ技术学习


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论