说明:以下例子采用的是DB first的模式
在之前的webform开发模式中我们习惯性性的会建立这样的一些类库:Model、DAL、BLL。。。但是在用了EF以后,我们创建的ADO.NET实体数据模型会默认的将实体类和对数据库的操作放在一起,这样会带来一个问题,就是当我们在应用层需要使用实体类的时候对数据库的操作也会直接暴露出来,由于学习ef不久,所以这个问题困扰了我很久,今天在博客园看了大虾的文章才明白原来微软早就预料到这个问题了。http://www.cnblogs.com/fangrobert/archive/2011/08/22/2150048.html
步骤一:
新建项目和各个类库
BLL:业务逻辑层
Model:实体
StatDataAccess:数据访问层
mvc3App:应用层
步骤二:
在StatDataAccess中新建ADO.NET Entity数据访问实体(XXX.edmx),双击打开XXX.edmx,右键“添加代码生成项”,选择”ADO.NET 自动跟踪实体生成器“,会生成两个T4模板文件Model1.tt和Model1.Context.tt
步骤三:将Model1.tt和XXX.edmx拷贝一份到Model类库项目中,右键运行Model1.tt生成实体类后,将Model类库中的XXX.edmx删除(注:如果数据库有更新再从StatDataAccess拷贝一份XXX.edmx过来再运行Model1.tt就是了)
步骤四:修改StatDataAccess项目中的T4文件Model1.Context.tt添加引用using Model;这样在生成数据操作类的时候才能找到实体类。打开XXX.edmx,右键-属性:代码生成策略由默认改为无(不进行此操作的话edmx还是会生成实体类)。
各项目的引用关系:
StatDataAccess项目引用Model
BLL项目引用Model和StatDataAccess
mvc3App引用BLL和Model
原文地址;http://hi.baidu.com/yyq745201/item/44ca14377d8da2bb124b1457