zoukankan      html  css  js  c++  java
  • Entity Framework CodeFirst For Oracle

    说明: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/ 

  • 相关阅读:
    单例
    Label自适应高度
    通知中心(以夜间模式为例)
    ios VFL屏幕自适应
    网络请求数据(同步POST,异步POST)
    linux 设备文件
    linux 文件存取 软硬联接的区别
    linux 磁盘管理与文件系统
    linux开机过程
    Build Antlr4 projects with eclipse java project template.
  • 原文地址:https://www.cnblogs.com/egood21/p/2893436.html
Copyright © 2011-2022 走看看