Entity Framework CodeFirst For Oracle
2013-02-05 22:17
501 查看
说明: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/
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/
相关文章推荐
- Entity Framework CodeFirst For Oracle[转]
- Entity Framework Code First for SQL Compact
- Entity Framework Code First在Oracle下的伪实现
- [转]Using Entity Framework (EF) Code-First Migrations in nopCommerce for Fast Customizations
- Entity Framework Code First在Oracle下的伪实现
- Entity Framework Code First在Oracle下的伪实现
- EntityFramework CodeFirst SQLServer转Oracle踩坑笔记
- Entity Framework Code First在Oracle下的伪实现(转)
- ASP.Net MVC极速开发:使用MVCScaffolding + EntityFramework CodeFirst
- EntityFramework Code First 手写代码实现生成数据库
- Entity Framework mvc Code First data migration
- Byteart Retail V2 - 基于Entity Framework Code First的领域驱动设计实践案例
- Entity Framework Code-First(9.6):DataAnnotations - StringLength Attribute
- Entity Framework Code-First(13):Configure Many-to-Many
- Entity Framework Code First使用者的福音 --- EF Power Tool使用记之二(问题探究)(转)
- How to execute a Stored Procedure with Entity Framework Code First
- C# ORM—Entity Framework 之Code first(代码优先)(二)
- Entity Framework Code First 学习日记(8)-一对一关系
- Entity Framework Code First数据库连接
- MySQL & Entity Framework Code First 数据表大小写的问题