VB.NET查询包含威力强大

开发 后端
VB.NET查询包含它的影音范围能够涉及到一些数据。我们将会在这篇文章中为大家详细介绍一下这方面的具体概念,帮助大家快速掌握。

VB.NET新版本中,出现了很多新的特性,帮助开发人员极大的提高了编程效率。不过这些初衷都是为了迎合.NET Framework新的数据框架——Linq。Linq的一个口号是“让查询无处不在”,它将类似SQL的语法强类型地引入到Visual Basic中,而且可以任意组合使用。不要以为只是把数据库的SQL写到VB中而已,那样就太小看Linq了。VB的目标是让一切包含数据的对象都可以用类SQL查询,包含数据库映射对象(DLinq),XML(XLinq),甚至是.NET Framework中的一切集合对象。

我们来看一个VB.NET查询包含的例子。假如employee类有firstname,lastname和age等属性。现在有一个list(of Employee)类型的集合叫做emp。假设我们要查询所有Age大于25的员工的姓名。回忆一下前面我们介绍的特性怎么给查询带来新的变化。首先我们给IEnumerable增加扩展方法Where:

  1. < Extension()> _  
  2. Public Function Where()Function Where(Of T)([Me] As 
    IEnumerable(Of T), predicate As Func(Of T, Boolean))_  
  3. As IEnumerable(Of T)  
  4. Dim result As New Collection(Of T)  
  5. For Each Dim item In [Me]  
  6. If predicate(item) Then result.Add(item)  
  7. Next  
  8. Return result  
  9. End Function 

注意func,这是.NET Framework将会增加的一组泛型委托之一,用于On-the-fly创建各种参数个数和类型的委托,而不必声明新的委托类型。这里Func用于表示一个断言。于是我们就把条件查询封装了。与此同时,我们还可以封装一个Select方法,用于数据类型转换,以此类推,还可以有OrderBy和GroupBy等等……这些就成为Linq的查询算符。

回忆一下,我们还有嵌套函数,于是可以按下列方法使用查询算符:

 

  1. Function F()Function F(obj As Employee)As Boolean  
  2. Return obj.Age > 25  
  3. End Function 

Dim result = emp.Where(AddressOf F)这里稍显麻烦的就是,我们需要自己定义函数,这样进行复杂查询就会写得很累,即使可能会有lambda表达式帮助,我们也希望寻求更容易理解的方法,那就是VB.NET查询包含Query Comprehension。新引入的Select,Where等查询关键字可以帮你完成前面介绍的一整套内容:#t#

Dim result = Select It From e In emp Where e.Age > 25一个简单的类似SQL的语法就帮助你生成了匿名的嵌套函数和所有算符的调用。注意It的用法,Select It就表示选择所有字段。我们只需要Employee的名字,那么就可以这样写:
Dim result = Select e.FirstName, e.LastName From e In emp Where e.Age > 25这样,select语句就会把查询的结果转化成一个tuple(匿名类型的实例),它仅包含你所需要的字段。慢慢你就会发现,VB.NET查询包含的威力可以延伸到你所能接触到的一切数据。这种关系型的语法很快就会代替for Each的手工迭代工作。

我们知道VB9将在xml方面有卓越的改进,当xml literal、XML后期绑定与VB.NET查询包含的语法结合在一起后,将体现出非凡的简洁和高效,这是C# 3.0等同期语言无法比拟的,我们介绍到XML特性后再继续介绍。

责任编辑:曹凯 来源: wewill.cn
相关推荐

2009-10-21 10:05:48

VB.NET Read

2010-01-22 17:48:46

VB.NET运算符重载

2009-06-24 15:45:32

VB.NET

2011-06-17 11:05:22

VB.NET

2009-10-29 14:02:24

VB和VB.NET比较

2009-10-14 12:51:41

VB.NET Data

2009-10-20 14:21:55

VB.NET fnSi

2009-11-02 17:12:01

VB和VB.NET

2010-01-22 16:39:46

VB.NET添加自动查

2009-11-03 09:26:13

VB.NET方法

2009-10-28 09:55:29

VB.NET MyCl

2009-10-20 09:39:04

VB.NET Butt

2009-10-15 17:50:48

VB.NET Spli

2010-01-13 10:53:24

VB.NET控件

2009-10-14 10:19:57

VB.NET Doma

2009-10-15 16:44:47

VB.NET Opti

2009-10-14 13:21:46

VB.NET Acco

2009-10-16 13:26:53

VB.NET Exce

2009-11-04 08:53:57

VB.NET AddH

2009-10-23 13:14:38

点赞
收藏

51CTO技术栈公众号