Entity FrameWork 笔记(三)POCO
2010-05-23 10:22 Henry Cui 阅读(2691) 评论(7) 收藏 举报在前面两篇文章中,我们看过了Entity FramwWork中的基本查询,在Entity FrameWork 4中提供了POCO的方式,POCO的全称是:Plain Old CLR Object,即提供了对传统CLR对象的支持。
DataBase
首先我们来看数据库里面的两张表:
Model
在这里我们就像添加普通的实体一样:
EDMX
我们新增一个edmx文件,选择刚才的两个表:
生成完成后我们需要注意的一点是,将Custom Tool设置成空,意思呢就是不需要生成代码:
自定义Context
我们来自定义Context:
 public class ProjectContext:ObjectContext
    {
        public ProjectContext()
            : base("name=HJRightPlatEntities",
                "HJRightPlatEntities")
        {
            _Projects = this.CreateObjectSet<Projects>();
            _Modules = this.CreateObjectSet<Modules>();
        }
        public ObjectSet<Projects> Projects {
            get {
                return _Projects;
            }
        }
        public ObjectSet<Modules> Modules
        {
            get
            {
                return _Modules;
            }
        }
        private ObjectSet<Projects> _Projects;
        private ObjectSet<Modules> _Modules;
    }
我们来写个测试的方法:
        [TestMethod()]
        public void ProjectsTest()
        {
            using (ProjectContext ctx = new ProjectContext())
            {
                var pros = from pro in ctx.Projects
                           where pro.ProjectName.Contains("报文消息查询系统")
                           select pro;
                Assert.AreEqual(1, pros.Count());
            }
        }
测试结果:
总结
在编写时要注意的是,编写的实体要跟在edmx中CSDL里面相对应,如果不同时,我们可以去修改实体,或则修改edmx中的CSDL跟Mappings。如果用过NHibernate的朋友,会感觉到现在的这个edmx就像一个mapping文件一样,不过还是有很大的差别的。
 
                    
                
                
            
        
浙公网安备 33010602011771号