vb的LINQ实现
vb实现LINQ非常简单的例子:
Dim numbers() As Integer = {1, 2, 3, 4, 5, 6, 7}
Dim allNumbers = From number In numbers
For Each num In allNumbers
Console.WriteLine(num & " ")
Next
LINQ中Let用法:
let关键字,可以让我们的linq查询不单单仅返回IEnumberable<T>类型的结果了,一个linq语句可以添加多个let关键字。
Public Sub TestLet()
Dim numbers() As Integer = {1, 2, 3, 4, 5, 6, 7}
'let关键字,允许我们定义第二个变量,并存储特定值。本例中,存储了,是否偶数的判断
'这意味着,返回值可以不单单只是一个IEnumerable(of T)类型的值了。
Dim myEvens = From number In numbers
Let isEven = (number Mod 2 = 0)
For Each even In myEvens
Console.WriteLine(even.number & " " & even.isEven)
Next
End Sub
LINQ中select用法:
上面的两个例子,我们省略了select关键字,这意味着我们使用了默认的select行为,即,选择了指定的每个查询结果(含let变量),逻辑上等同于select *.使用select关键字,我们可以选择或者组合我们想要的结果。同时重新确定变量的作用域,因为linq查询语句只公开select的内容。
Dim customerInfo = From cust In Customers, ord In cust.Orders _
Select myDate = ord.OrderDate, _
name = cust.FirstName & cust.LastName For Each info In customerInfo
Console.WriteLine(info.myDate & info.name)
Next
LINQ中的查询结果
上面的例子中,查询结果均使用了匿名类型。匿名类型允许你可以在select子句中指定不同数量的字段,而无需预先指定,由特定字段组合出来的准确类型。
编译器会推断出匿名类型的结构。匿名类型也是强类型的。
LINQ的延迟查询
查询声明实际上不会检索这些数据;只在执行需要数据的操作时,才会导致检索这些数据,这样你可以将查询分成几个逻辑部分,并且仍能实现,只要运行一次就可以得到结果的性能优势。
但是像count之类的方法,是需要立即执行的。
立即执行demo:
Dim customerInfo = From cust In Customers, ord In cust.Orders _
Select myDate = ord.OrderDate, _
name = cust.FirstName & cust.LastName Dim count = customerInfo.Count
延迟执行demo:
Dim seattleCustomers = From cust In Customers
Where cust.City = "Seattle"
Dim recentOrders = From ord In orders
Where ord.OrderDate.Year = 2012 Dim cusInfos = From cust In seattleCustomers, ord In recentOrders
Where cust.CustomerId = ord.CustomerId
Select name = cust.LastName & ", " & cust.FirstName, _
cust.CustomerId, ord.OrderDate
Order By OrderDate, name '上面LINQ只有在此处运行时,才被执行
For Each custInfo In cusInfos
'take action on the data here
Next
参考文章:
http://msdn.microsoft.com/zh-cn/magazine/cc163401.aspx
vb的LINQ实现的更多相关文章
- vb.net Linq 筛选(像 select distinct) DateTable 日期数据中的年份
Private Sub initDDLByYear(ByVal dt As DataTable) ddlByYear.Items.Clear() ddlByYear.Items.Add(") ...
- VB.NET vs. C#
VB.NET Program Structure C# Imports System Namespace Hello Class HelloWorld Overloads Shar ...
- C# 4.0 的 Visual Studio 2010 示例
C# 4.0 的 Visual Studio 2010 示例 我们将 C# 示例分为两种不同的类别: 语言示例 LINQ 示例 语言示例 语言示例帮助您熟悉各种 C# 语言功能.这些示例包含在 Lan ...
- 在VB中使用Linq To SQLite注意事项
昨天使Linq To SQLite 支持VB,今天在VB中写了几条Linq语句,发现了几个问题: 1.在Linq To SQLite中的Linq语句查询后并不是得到的匿名数据类,而是将Linq转换为S ...
- 在VB中利用Nuget包使用SQLite数据库和Linq to SQLite
上午解决了在C#中利用Nuget包使用SQLite数据库和Linq to SQLite,但是最后生成的是C#的cs类文件,对于我这熟悉VB而对C#白痴的来说怎么能行呢? 于是下午接着研究,既然生成的是 ...
- VB.NET中使用Linq TO SQL添加数据后获得自增长列ID
VB.NET中使用Linq TO SQL添加数据后获得自增长列ID: Dim tempOrdre As New Order With { .CustomerID = cmbCustomerName.S ...
- [转载代码]VB.NET 中查询 Linq to SQL 执行时的SQL语句
在搜索使用LINQ TO SQL 添加数据后获得自增长ID的方法时,发现C#可以使用DebuggerWritter把使用Linq to SQL执行的SQL语句显示到即时窗口,于是在网上搜索到在VB.N ...
- VB.NET中LINQ TO List泛型查询语句(分组,聚合函数)
Public Class LinqToList 'LINQ在C#中使用比较方便,但是在VB中使用比较麻烦,复杂,和C#用法并不太一样 Dim listNew As List(Of Product) = ...
- 使用Microsoft Roslyn提取C#和VB.NET源代码中的字符串常量
Microsoft Roslyn是微软.NET“编译器即服务(Compiler as a Service)”的主要产品,它提供了开放的编译器API,并为源代码产生.分析和重构提供了新一代的语言对象模型 ...
随机推荐
- mysql复制表
create table 表名 like 要复制的表名 //复制表结构 insert into 表名 select * from 要复制的表名 //复制数据 方法2,一般不推荐,如果后台加数据,可 ...
- java编程小技巧
1.缩进与反缩进 缩进:tab 反缩进:shift+tab 2.整段注释和取消整段注释 整段注释:ctrl+shift+/ 取消整段注释:ctrl+shift+\
- Spring4.0学习笔记(4) —— 使用外部属性文件
1.配置xml文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="htt ...
- Redis+PHP扩展的安装和Redis集群的配置 与 PHP负载均衡开发方案
以前有想过用 Memcache 实现M/S架构的负载均衡方案,直到听说了 Redis 后才发现它做得更好.发了几天时间研究了一下 Redis ,感觉真的很不错,特整理一下! 以下操作都是在 SUSE ...
- 在centos服务器上配置gitlab钩子引发的一系列问题
为了给公司的服务器上搭建gitlab环境并且配置钩子(实现在本地git push之后服务器自动git pull),整了好久,最后终于把问题解决了,下面是记录安装gitlab之后引发的一系列问题: 首先 ...
- c++四则运算代码
//Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--& ...
- 【HDOJ】1315 Basic
这道题目巨坑啊,注意__int64,int wa了一个下午. #include <cstdio> #include <cstring> #include <cstdlib ...
- HDU5266---pog loves szh III (线段树+LCA)
题意:N个点的有向树, Q次询问, 每次询问区间[L, R]内所有点的LCA. 大致做法:线段树每个点保存它的孩子的LCA值, 对于每一次询问只需要 在线段树查询即可. #include <bi ...
- fzu1759:数论高次幂降幂
题目大意: 求 a^b mod c的值..但是b会非常大(10^1000000) 所以需要用到一个数论公式: A^x = A^(x % Phi(C) + Phi(C)) (mod C) 证明见ac大神 ...
- GF(2^8)乘法
最近在学AES,实现了一下伽罗瓦域(2^8)乘法. 至于什么是伽罗瓦域解释起来比较复杂,我也不一定能解释清楚,自行google.这里只是给出一个简单直观的实现. #include<iostrea ...