最近研究了下ORM工具。总结一下。
之前有个小项目基于.Net40的WinForm。升级改造,想用ORM,由此引起。
第一选择是SqlSugar,国内团队制作,好用的很,但是.Net最低支持到4.5,而.Net45是不能在WinXP下运行,故可惜的放弃掉。
然后,找能在.Net40下运行的ORM,DosORM进入视野,但是发现有缺点,DosORM需要Model层都继承Entity类,而这个类在ORM.dll里,这样Model层将和ORM耦合,非常不好。而且DosTools工具生成的Model层,要求set里有onchange函数,而且还有内嵌类用于字段描述,简单的POCO,DosORM无法Update操作,造成Model层不干净。不佳。
转而,又延伸到Dapper,发现不错,1.52以下支持可以.Net40,对Model层简单set,get即可,无依赖,干净。缺点是它的CUDR需要写一些SQL,感觉不好,但是有个Dapper.SimpleCUDR的项目,引用后,可以支持简单泛型写法。那就选他了。其实在普通项目对DB层的需要,就是对单表的增删改查,多表的左连接查询,多表的事务更新,没有特别复杂的需求。
项目层次是,UI层引用Service层。Service层引用DB层。Model是独立的。DB层里包含Dapper和数据库连接器。Service层里有Dto,通过AutoMapper转换Dto和Model。从而达到,UI与Service解耦,Service与数据库解耦。
Dto放在Service层好,还是Model项目里好?有待验证。