Linq概念理解
Linq,中文叫做语言集成查询。直白的理解就是:将对数据的查询集成到语言中去(如C#)。
通常,我们从数据库中操作,需要根据不同的条件筛选出不同的记录出来。对应不同的条件,我们写不同的函数来过滤相应的记录。这样将会相当麻烦。每当相按某一条件过滤查询时,就要扩展一个相应方法。如果直接像在数据库中使用sql语句来该多方便呀。什么函数都不用写。只按select from where order by 就搞定了。
Linq,正是提供了这样的功能,将类似于sql中的这种查询,提供到了C#中。于是我们可以很“无耻”的这样获取数据:
一个Book类,这个类是一个映射类,和数据库表相映射:
[Table]
public class Book
{
///
/// 图书名称
///
[Column]
public string Title { get; set; }
///
/// 单价
///
[Column(DbType = "numeric(5, 2)")]
public float Price { get; set; }
///
/// 作者
///
[Column]
public string Author { get; set; }
///
/// ISBN号
///
[Column]
public string ISBN { get; set; }
}
数据查询:
DataContext db = new DataContext("Data Source=localhost;Initial Catalog=db;User ID=sa;Password=sa");
var result = from book in db.GetTable<Book>()
where book.Price > 50
orderby book.Price
select new { Key = book.Title, Value = book.Price };
foreach (var item in result)
Console.WriteLine("Key:{0}-Value:{1}",item.Key,item.Value.ToString());
哈哈,是不是就像使用sql一样。这样我们就可省略自己定义过滤函数,直接写一个类sql搞定。
这是最初步的理解。