Entity Framework CodeFirst For Oracle

來源:互聯網
上載者:User

說明:1)簡單樣本  2)非純粹的CodeFirst,更多的是DbFirst+CodeFirst方式相結合。3)只需用Oracle最新版的ODAC,不需要第三方驅動。Web應用需要web.config配置。4) 重點:此寫法可支援多資料庫(理論支援EF驅動的都可以),且Model名稱和資料庫欄位名稱不一致的情況。特別適用於舊系統的移動延伸開發。 

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://dotnetspeak.com/index.php/2012/01/oracle-odp-and-entity-framework-code-first-4-2/ 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.