我有一个像这样的简单类:
public class User
{
public Guid Id{ get; set; }
public string UserName { get; set; }
public byte[] RowVersion { get; set; }
}
Db tabale中的Rowversion列获取自动值。当我使用dapper进行Inser时
var result = db.Execute("[dbo].[User_Insert]", user, trans,commandType:CommandType.StoredProcedure);
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
答案 0 :(得分:2)
您可以传入一个只包含所需属性的匿名对象。
var result = db.Execute("[dbo].[User_Insert]", new { user.Id, user.UserName }, trans, commandType:CommandType.StoredProcedure);
或者,您可以使用Dapper Contrib扩展并创建一个映射类,它允许您忽略特定属性。