.Net Core2.0 EF Fluent API的配置方法

一、实体:
此处跟Framework无差,写法上如下

using System;

namespace Entities
{
    public class sys_account {
        public string account{ get; set; }
        public string name{ get; set; }
        public string nickname{ get; set; }
        public string password{ get; set; }
        public string email{ get; set; }
 }
}

二、配置映射

.NetCore2.0下的FluentAPI无法类似Framework一样通过继承EntityTypeConfiguration来配置实体而是改为需要实现IEntityTypeConfiguration通过Configure方法进行配置
如果找不到ToTable方法,可以在NuGet上安装Microsoft.EntityFrameworkCore.Relational,注意安装包版本要和你的EFCore版本相同!

using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;

namespace DDD.Data.MapConfig
{
    public class sys_accountMap : IEntityTypeConfiguration<sys_account>
    {
       public void Configure(EntityTypeBuilder<sys_account> builder)
        {
            builder.ToTable("sys_account", "db_admin")//db_admin为数据库架构,原始架构可以不填
                .HasKey(c=>c.account);
              //多主键映射如下
              //.HasKey(c=>new{ c.account,c.name });
        }
    }
}

三、配置上下文

在配置上下文上core2.0提供了modelBuilder.ApplyConfiguration方法,替代Framework中的modelBuilder.Configurations.AddFromAssembly

using Entities;
using Microsoft.EntityFrameworkCore;
using System;
using System.Linq;
using System.Reflection;

namespace Data
{
    public class dbEntities : DbContext
    {
        public oaEntities(DbContextOptions<dbEntities> options)
            : base(options)
        {
            
        }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            var typesToRegister = Assembly.GetExecutingAssembly().GetTypes()
                .Where(q => q.GetInterface(typeof(IEntityTypeConfiguration<>).FullName) != null);

            foreach (var type in typesToRegister)
            {

                dynamic configurationInstance = Activator.CreateInstance(type);
                modelBuilder.ApplyConfiguration(configurationInstance);
            }
            base.OnModelCreating(modelBuilder);
        }
        
        /// <summary>
        /// 账号目录
        /// </summary>
        public DbSet<sys_account> sys_account { get; set; }
 
    }
}

以下文字可能有些地方表述上不标准,请见谅

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值