Linq概念理解

    Linq,中文叫做语言集成查询。直白的理解就是:将对数据的查询集成到语言中去(如C#)。

    通常,我们从数据库中操作,需要根据不同的条件筛选出不同的记录出来。对应不同的条件,我们写不同的函数来过滤相应的记录。这样将会相当麻烦。每当相按某一条件过滤查询时,就要扩展一个相应方法。如果直接像在数据库中使用sql语句来该多方便呀。什么函数都不用写。只按select from where order by 就搞定了。

    Linq,正是提供了这样的功能,将类似于sql中的这种查询,提供到了C#中。于是我们可以很“无耻”的这样获取数据:

    一个Book类,这个类是一个映射类,和数据库表相映射:

    [Table]
public class Book
{
    
/// 
    
/// 图书名称
     
/// 
    [Column]
    
public string Title { getset; }
    
/// 
    
/// 单价
     
/// 
    [Column(DbType = "numeric(5, 2)")]
    
public float Price { getset; }
    
/// 
    
/// 作者
     
/// 
    [Column]
    
public string Author { getset; }
    
/// 
    
/// ISBN号
     
/// 
    [Column]
    
public string ISBN { getset; }
}

数据查询:

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搞定。

这是最初步的理解。

转载于:https://www.cnblogs.com/oldsea/archive/2010/05/19/1738777.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值