很多开源的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,不小心把罗斯文数据库也打包进去了。
喜欢的朋友看一下吧。