如何忽略Dapper中的某些属性?

M.A*_*zad 9 c# dapper

我有一个像这样的简单类:

public class User
{
    public Guid Id{ get; set; }
    public string UserName { get; set; }
    public byte[] RowVersion { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

Db tabale中的Rowversion列获取自动值.当我使用dapper进行Inser时

var result = db.Execute("[dbo].[User_Insert]", user, trans,commandType:CommandType.StoredProcedure);
Run Code Online (Sandbox Code Playgroud)

Dapper为所有属性生成参数,我得到这样的错误

过程或函数User_Insert指定了太多参数.

如何在Dapper参数中忽略Rowversion?

我的程序代码是:

 ALTER PROCEDURE [In4].[User_Insert] 
       @Id         uniqueidentifier,
       @UserName    nvarchar(4000)= NULL   
AS 
BEGIN
   insert into [In4].[Users] ([Id], [UserName])
                 VALUES (@Id, @UserName) 
End
Run Code Online (Sandbox Code Playgroud)

chr*_*ano 2

您可以传入一个仅包含您想要的属性的匿名对象。

var result = db.Execute("[dbo].[User_Insert]", new { user.Id, user.UserName }, trans, commandType:CommandType.StoredProcedure);
Run Code Online (Sandbox Code Playgroud)

或者,您可以使用Dapper Contrib扩展并创建一个映射类,它允许您忽略特定属性。