- ASP.NET 教程
- ASP.NET - 首页
- ASP.NET - 简介
- ASP.NET - 环境
- ASP.NET - 生命周期
- ASP.NET - 第一个示例
- ASP.NET - 事件处理
- ASP.NET - 服务器端
- ASP.NET - 服务器控件
- ASP.NET - HTML 服务器控件
- ASP.NET - 客户端
- ASP.NET - 基本控件
- ASP.NET - 指令
- ASP.NET - 状态管理
- ASP.NET - 验证器
- ASP.NET - 数据库访问
- ASP.NET - ADO.NET
- ASP.NET - 文件上传
- ASP.NET - 广告轮播
- ASP.NET - 日历控件
- ASP.NET - 多视图
- ASP.NET - 面板控件
- ASP.NET - AJAX 控件
- ASP.NET - 数据源
- ASP.NET - 数据绑定
- ASP.NET - 自定义控件
- ASP.NET - 个性化设置
- ASP.NET - 错误处理
- ASP.NET - 调试
- ASP.NET - LINQ
- ASP.NET - 安全性
- ASP.NET - 数据缓存
- ASP.NET - Web 服务
- ASP.NET - 多线程
- ASP.NET - 配置
- ASP.NET - 部署
- ASP.NET 资源
- ASP.NET - 快速指南
- ASP.NET - 有用资源
- ASP.NET - 讨论
ASP.NET - LINQ
大多数应用程序都是以数据为中心的,但是大多数数据存储库都是关系数据库。多年来,设计师和开发人员设计了基于对象模型的应用程序。
对象负责连接到数据访问组件——称为数据访问层 (DAL)。这里有三个需要考虑的要点:
应用程序中所需的所有数据并非都存储在同一个源中。该源可以是关系数据库、某些业务对象、XML 文件或 Web 服务。
访问内存中对象比访问数据库或 XML 文件中的数据更简单且成本更低。
访问的数据不会直接使用,而是需要进行排序、排列、分组、更改等操作。
因此,如果有一个工具可以轻松访问各种数据,允许从不同的数据源连接数据并执行标准数据处理操作,只需几行代码,那将非常有用。
LINQ 或语言集成查询就是这样一种工具。LINQ 是对 .NET Framework 3.5 及其托管语言的一组扩展,它将查询设置为对象。它定义了一种通用的语法和编程模型,可以使用通用的语言查询不同类型的数据。
.NET Framework 3.5 中的 LINQ 和 C# 和 VB 编译器实现了诸如 Select、Project、Join、Group、Partition、Set 等关系运算符,这些运算符支持 LINQ 语法,可以无需借助 ADO.NET 来处理配置好的数据存储。
例如,使用 C# 中的 LINQ 查询查询 Northwind 数据库中的 Customers 表,代码如下:
var data = from c in dataContext.Customers where c.Country == "Spain" select c;
其中
“from”关键字逻辑上循环遍历集合的内容。
使用“where”关键字的表达式对集合中的每个对象进行评估。
“select”语句选择要添加到返回列表中的已评估对象。
“var”关键字用于变量声明。由于返回对象的精确类型未知,因此它表示信息将动态推断。
LINQ 查询可以应用于继承自 IEnumerable<T> 的任何承载数据的类,其中 T 是任何数据类型,例如 List<Book>。
让我们来看一个例子来理解这个概念。此示例使用以下类:Books.cs
public class Books
{
public string ID {get; set;}
public string Title { get; set; }
public decimal Price { get; set; }
public DateTime DateOfRelease { get; set; }
public static List<Books> GetBooks()
{
List<Books> list = new List<Books>();
list.Add(new Books { ID = "001",
Title = "Programming in C#",
Price = 634.76m,
DateOfRelease = Convert.ToDateTime("2010-02-05") });
list.Add(new Books { ID = "002",
Title = "Learn Java in 30 days",
Price = 250.76m,
DateOfRelease = Convert.ToDateTime("2011-08-15") });
list.Add(new Books { ID = "003",
Title = "Programming in ASP.Net 4.0",
Price = 700.00m,
DateOfRelease = Convert.ToDateTime("2011-02-05") });
list.Add(new Books { ID = "004",
Title = "VB.Net Made Easy",
Price = 500.99m,
DateOfRelease = Convert.ToDateTime("2011-12-31") });
list.Add(new Books { ID = "005",
Title = "Programming in C",
Price = 314.76m,
DateOfRelease = Convert.ToDateTime("2010-02-05") });
list.Add(new Books { ID = "006",
Title = "Programming in C++",
Price = 456.76m,
DateOfRelease = Convert.ToDateTime("2010-02-05") });
list.Add(new Books { ID = "007",
Title = "Datebase Developement",
Price = 1000.76m,
DateOfRelease = Convert.ToDateTime("2010-02-05") });
return list;
}
}
使用此类的网页有一个简单的标签控件,它显示书籍的标题。Page_Load 事件创建一个书籍列表,并使用 LINQ 查询返回标题。
public partial class simplequery : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
List<Books> books = Books.GetBooks();
var booktitles = from b in books select b.Title;
foreach (var title in booktitles)
lblbooks.Text += String.Format("{0} <br />", title);
}
}
页面执行后,标签显示查询结果。
上面的 LINQ 表达式
var booktitles = from b in books select b.Title;
等效于以下 SQL 查询:
SELECT Title from Books
LINQ 运算符
除了到目前为止使用的运算符外,还有其他一些运算符实现了所有查询子句。让我们来看一些运算符和子句。
Join 子句
SQL 中的“join 子句”用于连接两个数据表并显示包含两个表中列的数据集。LINQ 也能够做到这一点。要检查这一点,请在之前的项目中添加另一个名为 Saledetails.cs 的类。
public class Salesdetails
{
public int sales { get; set; }
public int pages { get; set; }
public string ID {get; set;}
public static IEnumerable<Salesdetails> getsalesdetails()
{
Salesdetails[] sd =
{
new Salesdetails { ID = "001", pages=678, sales = 110000},
new Salesdetails { ID = "002", pages=789, sales = 60000},
new Salesdetails { ID = "003", pages=456, sales = 40000},
new Salesdetails { ID = "004", pages=900, sales = 80000},
new Salesdetails { ID = "005", pages=456, sales = 90000},
new Salesdetails { ID = "006", pages=870, sales = 50000},
new Salesdetails { ID = "007", pages=675, sales = 40000},
};
return sd.OfType<Salesdetails>();
}
}
在 Page_Load 事件处理程序中添加代码,以使用 join 子句查询两个表。
protected void Page_Load(object sender, EventArgs e)
{
IEnumerable<Books> books = Books.GetBooks();
IEnumerable<Salesdetails> sales = Salesdetails.getsalesdetails();
var booktitles = from b in books join s in sales on b.ID equals s.ID
select new { Name = b.Title, Pages = s.pages };
foreach (var title in booktitles)
lblbooks.Text += String.Format("{0} <br />", title);
}
生成的页面如下所示:
Where 子句
“where 子句”允许向查询添加一些条件过滤器。例如,如果您想查看页数超过 500 的书籍,请将 Page_Load 事件处理程序更改为:
var booktitles = from b in books join s in sales on b.ID equals s.ID
where s.pages > 500 select new { Name = b.Title, Pages = s.pages };
查询仅返回页数超过 500 的那些行。
Orderby 和 Orderbydescending 子句
这些子句允许对查询结果进行排序。要按价格对书籍的标题、页数和价格进行排序,请在 Page_Load 事件处理程序中编写以下代码:
var booktitles = from b in books join s in sales on b.ID equals s.ID
orderby b.Price select new { Name = b.Title, Pages = s.pages, Price = b.Price};
返回的元组如下:
Let 子句
let 子句允许定义变量并为其分配从数据值计算的值。例如,要从上述两个销售额计算总销售额,您需要计算:
TotalSale = Price of the Book * Sales
为此,请在 Page_Load 事件处理程序中添加以下代码片段:
let 子句允许定义变量并为其分配从数据值计算的值。例如,要从上述两个销售额计算总销售额,您需要计算:
var booktitles = from b in book join s in sales on b.ID equals s.ID
let totalprofit = (b.Price * s.sales)
select new { Name = b.Title, TotalSale = totalprofit};
生成的查询页面如下所示: