|
系列文章导航:
不能不说的C#特性-迭代器(下),yield以及流的延迟计算
走进Linq-Linq to SQL How do I(1)
走进Linq-Linq to SQL How do I(2)
走进Linq-Linq to SQL How do I(3)
走进Linq-Linq to SQL源代码赏析 Table
走进Linq-Linq to SQL源代码赏析之Provider的初始化
走进Linq-Linq to SQL源代码赏析,通过Linq to SQL看Linq
How Do I第一篇,难度系数50,定位为入门级。
上一篇对Linq to SQL做了一个大致的介绍,从这一篇起,将对要完成一项Linq to SQL的Case要做的一些事情,主要从细节上做一些讲解。不会很深入,但是却又是必须的。为了使讲解不落于泛泛而谈,我们首先来构建实例:
还是以博客园的系统为例子,既然称Linq to SQL为一个ORM框架,ORM,对象-关系 映射,既然O在前关系在后,说明O为重,关系是根据O得来的,那么我们就先新建一些Entity Object吧。在一个博客系统里最常见的就是User,Blog,Post。
一个用户有且仅有一个博客,而一个博客可以有零篇或者多篇博客文章。根据这个描述我们来建立Entity:
Step 1 建立实体对象
User系列文章导航:
不能不说的C#特性-迭代器(下),yield以及流的延迟计算
走进Linq-Linq to SQL How do I(1)
走进Linq-Linq to SQL How do I(2)
走进Linq-Linq to SQL How do I(3)
走进Linq-Linq to SQL源代码赏析 Table
走进Linq-Linq to SQL源代码赏析之Provider的初始化
走进Linq-Linq to SQL源代码赏析,通过Linq to SQL看Linq
Step 3:建立映射
对象也有了,关系也有了,那剩下的是什么?对,就是映射,我们怎样将对象映射到数据库表上?
我们从最简单的Post开始吧:
////// 博客文章类
/// 这个类和数据库里的posts表对应,由于
/// 类名和表名不一样,所以需要显式的指明Table特性的Name属性
/// 如果是一致的则无需指明了
///
[Table(Name="posts")]
public class Post
{
///
/// 文章Id
/// 这个对应posts表里的postid
/// 这个字段还是一个主键,所以Column特性的IsPrimaryKey属性为true
///
[Column(Name="postid",IsPrimaryKey=true)]
public int Id { get; set; }
///
/// 文章从属的博客
/// 这个对应着表里的blogid,名字一样所以只需要加个Column特性就可以了
/// 下面几个也是一样的意思
///
[Column]
public int BlogId { get; set; }
///
/// 标题
///
[Column]
public string Title { get; set; }
///
/// 内容
///
[Column]
public string Body { get; set; }
///
/// 发表时间
///
[Column]
public DateTime CreateDate { get; set; }
}
系列文章导航:
不能不说的C#特性-迭代器(下),yield以及流的延迟计算
走进Linq-Linq to SQL How do I(1)
走进Linq-Linq to SQL How do I(2)
走进Linq-Linq to SQL How do I(3)
走进Linq-Linq to SQL源代码赏析 Table
走进Linq-Linq to SQL源代码赏析之Provider的初始化
走进Linq-Linq to SQL源代码赏析,通过Linq to SQL看Linq
实际上,如果光返回一个Table,而不在上面施加任何的操作,遍历的时候是返回整个表的数据,在上一篇我还提到,为了跟踪,我们最好将dbContext.Log给显示出来。如果你添加了下面这行代码:
dbContext.Log = Console.Out;
系列文章导航:
不能不说的C#特性-迭代器(下),yield以及流的延迟计算
走进Linq-Linq to SQL How do I(1)
走进Linq-Linq to SQL How do I(2)
走进Linq-Linq to SQL How do I(3)
走进Linq-Linq to SQL源代码赏析 Table
走进Linq-Linq to SQL源代码赏析之Provider的初始化
走进Linq-Linq to SQL源代码赏析,通过Linq to SQL看Linq
但是不是所有的C#的方法都可以使用呢?答案是否定的。比如:var posts = from post in dbContext.GetTable<Post>()
where post.Title.StartsWith("y")
select post.CreateDate.ToString("yyyy-MM-dd");
系列文章导航:
不能不说的C#特性-迭代器(下),yield以及流的延迟计算
走进Linq-Linq to SQL How do I(1)
走进Linq-Linq to SQL How do I(2)
走进Linq-Linq to SQL How do I(3)
走进Linq-Linq to SQL源代码赏析 Table
走进Linq-Linq to SQL源代码赏析之Provider的初始化
走进Linq-Linq to SQL源代码赏析,通过Linq to SQL看Linq
Step 6:更新数据
可以插入肯定就可以更新了,下面就来看看如何更新呢:
做更新的时候,你首先得从数据库查询出该对象,然后对该对象的属性进行修改,最后更新到数据库:
var posts = from post in dbContext.GetTable<Post>()where post.BlogId == 2
select post;
foreach (var post in posts)
post.BlogId = 5;
dbContext.SubmitChanges();
it知识库:走进Linq-Linq to SQL How do I(1),转载需保留来源!
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。