EF fluent API如何配置主键不自动增长

在Dbcontext中作如下添加:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{ 
     modelBuilder.Entity<bbsUsersEntity>().Property(e => e.UserId).
HasDatabaseGeneratedOption(DatabaseGeneratedOption.None); }

 

转载于:https://www.cnblogs.com/caojiannan/p/8711089.html

EF Code First 是 Entity Framework 的一种模型定义方式,它允许开发者通过定义 .NET 类来创建数据库模式。在使用 EF Code First 设计数据库模型时,通常情况下,每个实体都会有一个主键来唯一标识记录。但是,有时候我们可能需要在两个实体之间建立关联,而这种关联并不是基于主键,我们称之为非主键关联。 在 EF Code First 中实现非主键关联通常需要使用 Fluent API 或者数据注解来配置。非主键关联可以通过配置两个表的某一个或多个共同字段来实现。例如,在两个实体 A 和 B 之间,它们没有共同的主键,但是有一个共同的字段,如 Name,可以用来建立它们之间的非主键关联。 使用 Fluent API 实现非主键关联的基本步骤如下: 1. 定义实体类,并在类中声明关联的属性。 2. 在 DbContext 的派生类中重写 OnModelCreating 方法。 3. 使用 Fluent API 配置主键关联,指定外键和关联的引用完整性。 具体代码示例如下: ```csharp public class A { public int Id { get; set; } public string CommonKey { get; set; } public ICollection<B> Bs { get; set; } } public class B { public int Id { get; set; } public string CommonKey { get; set; } public ICollection<A> As { get; set; } } protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity<A>().HasMany(a => a.Bs) .WithRequired(b => b.A) .HasForeignKey(b => b.CommonKey); } ``` 在这个例子中,A 和 B 两个实体通过 CommonKey 字段建立了非主键关联。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值