设计是否可以更合理一点?——关于ORM中业务实体的讨论
今天看到David Hayden写的Castle ActiveRecord - Active Record Pattern Built on NHibernate - Rapid Application Development文章,其中他的实体类设计如下:
[ActiveRecord("Posts")]
public class Article : ActiveRecordBase<Post>
{
private int _id;
[PrimaryKey(PrimaryKeyType.Native, "PostId")]
public int Id
{
get{ return _id;}
set{ _id = value;}
}
private int _blogId;
[Property]
public int BlogId
{
get{ return _blogId;}
set{ _blogId = value;}
}
private int _categoryId;
[Property]
public int CategoryId
{
get{ return _categoryId;}
set{ _categoryId = value;}
}
private string _title = string.Empty;
[Property]
public string Title
{
get{ return _title;}
set{ _title = value;}
}
private string _description = string.Empty;
[Property]
public string Description
{
get{ return _description;}
set{ _description = value;}
}
}
public class Article : ActiveRecordBase<Post>
{
private int _id;
[PrimaryKey(PrimaryKeyType.Native, "PostId")]
public int Id
{
get{ return _id;}
set{ _id = value;}
}
private int _blogId;
[Property]
public int BlogId
{
get{ return _blogId;}
set{ _blogId = value;}
}
private int _categoryId;
[Property]
public int CategoryId
{
get{ return _categoryId;}
set{ _categoryId = value;}
}
private string _title = string.Empty;
[Property]
public string Title
{
get{ return _title;}
set{ _title = value;}
}
private string _description = string.Empty;
[Property]
public string Description
{
get{ return _description;}
set{ _description = value;}
}
}
注意到出现了下面这样的两个属性:
public int BlogId
public int CategoryId
public int CategoryId
在这个业务实体中,对于Article对象来说,更直观的应该说它属于哪一个Blog,哪一个Category,而不是指定一个整型的值,这种用ID的设计其实是把把数据库结构带入到了业务实体中。我们知道引入ORM,使得我们可以用面向对象的思维来考虑实体间的关系,如果继续使用ID来解决,引入ORM的作用可能就大打折扣了,因此,是否把实体类修改为如下这样更合理一些呢?
[ActiveRecord("Posts")]
public class Article : ActiveRecordBase<Post>
{
private int _id;
[PrimaryKey(PrimaryKeyType.Native, "PostId")]
public int Id
{
get{ return _id;}
set{ _id = value;}
}
private Blog _blog;
[Property]
public Blog Blog
{
get{ return _blog;}
set{ _blog = value;}
}
private Category _category;
[Property]
public Category Category
{
get{ return _category;}
set{ _category = value;}
}
private string _title = string.Empty;
[Property]
public string Title
{
get{ return _title;}
set{ _title = value;}
}
private string _description = string.Empty;
[Property]
public string Description
{
get{ return _description;}
set{ _description = value;}
}
}
public class Article : ActiveRecordBase<Post>
{
private int _id;
[PrimaryKey(PrimaryKeyType.Native, "PostId")]
public int Id
{
get{ return _id;}
set{ _id = value;}
}
private Blog _blog;
[Property]
public Blog Blog
{
get{ return _blog;}
set{ _blog = value;}
}
private Category _category;
[Property]
public Category Category
{
get{ return _category;}
set{ _category = value;}
}
private string _title = string.Empty;
[Property]
public string Title
{
get{ return _title;}
set{ _title = value;}
}
private string _description = string.Empty;
[Property]
public string Description
{
get{ return _description;}
set{ _description = value;}
}
}
即用这里的两个属性来代替整型的ID:
public Category Category
public Blog Blog
public Blog Blog
估计也有很多朋友会这样去用,下午跟一个朋友讨论时,他说修改前加载Article对象时,加载的仅仅是2个ID,而修改后却要加载Blog,Category对象所有的属性,是否存在性能上的下降?欢迎大家就这个问题说出你的看法。
支持TerryLee的创业产品Worktile
Worktile,新一代简单好用、体验极致的团队协同、项目管理工具,让你和你的团队随时随地一起工作。完全免费,现在就去了解一下吧。
https://worktile.com
Worktile,新一代简单好用、体验极致的团队协同、项目管理工具,让你和你的团队随时随地一起工作。完全免费,现在就去了解一下吧。
https://worktile.com