在对 .Net Core Web Api 的 POST 请求中省略 Id 属性
Posted
技术标签:
【中文标题】在对 .Net Core Web Api 的 POST 请求中省略 Id 属性【英文标题】:Omit Id property in POST request to .Net Core Web Api 【发布时间】:2021-11-20 16:40:28 【问题描述】:我有一个小的 .Net 5 Web Api 项目。 应用代码优先方法。微软 SQL。 EF 核心。
问题是 - 当控制器接收没有 Id
的模型时 - 它失败 - “发生了一个或多个验证错误。”。如果控制器收到Id: 0
- 没关系,它可以工作。
问题是 - 是否可以在 POST 请求中省略 Id
属性?
我想从请求中完全省略 Id
。
型号:
public class Playback
public int Id get; set;
[Required]
public string Video_Name get; set;
[Required]
public string Video_Duration get; set;
public string Playback_User get; set;
public int Playback_Duration get; set;
控制器:
public async Task<IActionResult> AddPlaybackEvent2([FromForm] Playback model)
Playback @event;
try
@event = new Playback();
@event.Video_Name = model.Video_Name;
@event.Video_Duration = model.Video_Duration;
@event.Playback_User = model.Playback_User;
@event.Playback_Duration = model.Playback_Duration;
_db.Playbacks.Add(@event);
_db.SaveChanges();
catch (Exception e)
return BadRequest(e.Message);
return Ok(@event);
在 MS SQL 中检查 - 已配置 Id 列的主键和标识增量。
【问题讨论】:
你使用fluent api来设置Id主键自增吗? @Den 不。我认为 EF Core 是自动完成的。我只是在 MS SQL 中打开表并确保 Id 列是启用标识增量的主键。 【参考方案1】:将此属性添加到您的模型。如果您使用代码优先方法,则需要在模型中进行设置
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id get; set;
【讨论】:
以上是关于在对 .Net Core Web Api 的 POST 请求中省略 Id 属性的主要内容,如果未能解决你的问题,请参考以下文章