[ORM]某人的ORM框架

  很多开源的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创建过滤器就行了

Code
///创建过滤器
        IFilter filter = manager.CreateFilter("UserName", userName, Operator.Equal);
UserInfo userInfo = manager.LoadOne(filter);

复合查询可以通过创建BooleanFilter对多个IFilter进行逻辑合并

Code
IFilter bFilter=manager.CreateBooleanFilter(leftFilter,rightFilter,LogicOperator.And);

经常会用到的一个比较复杂的查询应该就是分页功能了吧,我的ORM框架对分页也有很好的支持

Code

为数据表写实体类是件很麻烦的事情,尤其是字段特别多的时候,这种苦力活不应该由我们来做啊,太浪费了,所以我写了一个自动生成实体类的小软件,偷懒一下。

EntityBuilder.rar 数据表实体类生成工具。

WebSite1.rar 这个是ORM框架的Demo,不小心把罗斯文数据库也打包进去了。

喜欢的朋友看一下吧。

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏