Entity Framework CodeFirst For Oracle[转]
2013-02-06 09:21 音乐让我说 阅读(524) 评论(0) 编辑 收藏 举报说明:1)简单示例 2)非纯粹的CodeFirst,更多的是DbFirst+CodeFirst方式相结合。3)只需用Oracle最新版的ODAC,不需要第三方驱动。4)相应的web.config配置。三步即可。
1. 声明 model, 并手动创建表结构,字段建议大写。
public class PageUser { public virtual string PId { get; set; } public virtual string UId { get; set; } }
2. Model和表 Mapping
public class PageUserMapping : EntityTypeConfiguration<PageUser> { protected string DbSchema { get; set; } public PageUserMapping() : this(null) { } public PageUserMapping(string dbSchema) { this.DbSchema = dbSchema; Property(c => c.UId).HasColumnName("UID"); Property(c => c.PId).HasColumnName("PID"); //设置主键 HasKey(c => new { c.UId,c.PId }); if (string.IsNullOrEmpty(DbSchema)) { ToTable("PAGEUSERS"); //表名 } else ToTable("PAGEUSERS", DbSchema); //Oracle等需要指定Schema,即登陆oracle的用户 } }
3. 继承 DbContext 的类中,重写
public class MContext : DbContext { protected override void OnModelCreating(DbModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); modelBuilder.Conventions.Remove<ModelNamespaceConvention>(); modelBuilder.Conventions.Remove<ModelContainerConvention>(); //此处重要 modelBuilder.Configurations.Add(new PageUserMapping("TEST")); } } }
到目前为止此为几个关键点,可以 using(var contxt=new MContext()) { ....} 使用了。
另:Web开发,Web.config 配置,当然要引用 Oracle.DataAccess 了。
<system.data> <DbProviderFactories> <remove invariant ="Oracle.DataAccess.Client" /> <add name="Oracle Data Provider for .NET" invariant="Oracle.DataAccess.Client" description="Oracle Data Provider for .NET" type="Oracle.DataAccess.Client.OracleClientFactory, Oracle.DataAccess, Version=4.112.3.0, Culture=neutral, PublicKeyToken=89b483f429c47342,processorArchitecture=x86" /> </DbProviderFactories> </system.data>
转载自:http://www.cnblogs.com/egood21/archive/2013/02/05/2893436.html
谢谢浏览!
作者:音乐让我说(音乐让我说 - 博客园)
出处:http://music.cnblogs.com/
文章版权归本人所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。