很多开源的ORM框架都需要配置,那实在是件很烦人的事情。我以前曾打算学NHibernate,开始还以为.net的Hibernate应该没Java的Hibernate用起来麻烦,结果在网上看了些教材,发觉那是一样的麻烦。说实话,只要是要配置的,我都没心情去做。一般的开源ORM框架都比较重量级的,虽然能满足我的需要,但功能实在是太多太复杂了,我压根儿很难用得上,而且用起来也麻烦,我还不如自己直接写代码来得快呢。我总结了一下平时做的项目,大部分的时候我只需要增、删、改、查这几个基本的功能就行了,其它的什么关联啊什么的,用得很少很少。想来想去,还是自己写个简单易用的ORM框架吧,满足一般的需求就够了。
许多ORM框架把许多代码都用在了配置和其它一些无用功的方面,这样做虽然更加的具有通用性,但同时也给使用者带来了许多麻烦的工作和性能上的损耗,而且体积也变得很大,代码复杂,难以维护。其实这部分的功能根本就没多大的用处,程序员又不是傻子,何必搞那么多的配置来纠错呢。根据约定优于配置的原则,制定一个规范,只要大家都按照约定的规则来使用就OK了,对于程序员来说,要做到这一点一点也不难。
我的ORM框架的约定是:
1,实体类名和数据表名相同。
2,主键是"表名ID",并且主键是自增的整数。
3,数据表的字段名和属性名相同。
4,正确使用。
只要遵循以上的约定,就可以正确的使用我的ORM框架了。
创建表的ORM管理:
//创建UserInfo表的管理者,DbConnectionString是数据库连接字符串名,在配置文件中设置
IORMManager<UserInfo> manager = ORMBuilder<UserInfo>.GetORMManager("DbConnectionString");
有了IORMManager,就可以执行数据操作了。
要进行条件查询也很简单,通过IORMManager创建过滤器就行了
///创建过滤器
IFilter filter = manager.CreateFilter("UserName", userName, Operator.Equal);
UserInfo userInfo = manager.LoadOne(filter);
复合查询可以通过创建BooleanFilter对多个IFilter进行逻辑合并
IFilter bFilter=manager.CreateBooleanFilter(leftFilter,rightFilter,LogicOperator.And);
经常会用到的一个比较复杂的查询应该就是分页功能了吧,我的ORM框架对分页也有很好的支持
///创建分页器
IPager<Products> pager = manager.GetPager();
/// <summary>
/// 返回第page页的记录
/// </summary>
/// <param name="page"></param>
/// <returns></returns>
public List<Products> GetProducts(int page)
{
return pager.Load(page);
}
/// <summary>
/// 返回总页数
/// </summary>
/// <returns></returns>
public int PageCount()
{
return pager.PageCount;
}