EF Core NotMapped、Column、Comment

一、NotMapped

模型中的每个实体类型都具有一组属性,这些属性 EF Core 将从数据库中读取和写入数据。 如果使用关系数据库,实体属性将映射到数据库表列。但当某个属性只用于展示,不需要映射到数据库,就需要使用 [NotMapped]属性

	[Table("QcwGoodss")]
    public class Goods : AuditedEntity<Guid>
    {
        /// <summary>
        /// 货品名称
        /// </summary>
        public string GoodsName { get; set; }
        /// <summary>
        /// 货品类型
        /// </summary>
        public string GoodsType { get; set; }
        /// <summary>
        /// 存放位置
        /// </summary>
        public string Location { get; set; }
        /// <summary>
        /// 货品数量
        /// </summary>
        public int GoodsNum { get; set; }

        /// <summary>
        ///  用于显示
        /// </summary>
        [NotMapped]
        public string GoodsCode { get { return GoodsName.Substring(0, 1) + ":" + Location; } }

        public virtual Guid InboundRecordId { get; set; }
        [ForeignKey(nameof(InboundRecordId))]
        public virtual InboundRecord InboundRecord { get; set; }
    }

二、Column

更改数据库字段名和字段的数据类型

		/// <summary>
        /// 货品类型
        /// </summary>
        [Column(TypeName = "varchar(200)")]
        [Column("GoodsTypeTest")]
        [StringLength(MaxCodeLength)]
        public string GoodsType { get; set; }

三、Comment

在数据库列上设置的任意文本注释,以允许您在数据库中记录架构

 		/// <summary>
        /// 存放位置
        /// </summary>
        [Comment("The URL of the blog")]
        [StringLength(MaxRemarkLength)]
        public string Location { get; set; }

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EF Core 触发器是在保存数据到数据库之前或之后执行的自定义逻辑。它们可以用于在数据更改发生时执行额外的操作,例如验证、日志记录或更新相关数据。 在 EF Core 中,可以使用 NuGet 软件包 EntityFrameworkCore.Triggered 来实现触发器功能。该软件包提供了一组接口和类,用于定义和注册触发器,并在适当的时机执行它们。 以下是一个示例,演示如何使用 EF Core 触发器: 1. 首先,安装 EntityFrameworkCore.Triggered NuGet 软件包: ```shell dotnet add package EntityFrameworkCore.Triggered ``` 2. 创建一个触发器类,实现 IBeforeSaveTrigger 或 IAfterSaveTrigger 接口,并实现相应的方法。例如,以下是一个在保存之前执行的触发器: ```csharp using EntityFrameworkCore.Triggered; public class MyBeforeSaveTrigger : IBeforeSaveTrigger<MyEntity> { public Task BeforeSave(ITriggerContext<MyEntity> context, CancellationToken cancellationToken) { // 在保存之前执行的逻辑 return Task.CompletedTask; } } ``` 3. 在 DbContext 中注册触发器。例如,以下是一个 DbContext 类的示例: ```csharp using EntityFrameworkCore.Triggered; public class MyDbContext : DbContext { protected override void OnModelCreating(ModelBuilder modelBuilder) { // 注册触发器 modelBuilder.Entity<MyEntity>() .HasBeforeSaveTrigger<MyBeforeSaveTrigger>(); } } ``` 通过以上步骤,你可以定义和注册 EF Core 触发器,并在保存数据到数据库之前或之后执行自定义逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值