1

我有以下一段代码(示例简化了一点):

public class Entity
{
    public int Id { get; set; }
    public TimeSpan Duration { get; set; }
    ...
}

...

public void Save(Entity e)
{
    if (e.Id == 0)
        _connection.Insert(e);
    else
        _connection.Update(); 
}

数据库是 Sql Server 2008R2,Duration 字段是 Time sql 数据类型。

当我在新实体上调用 Save 时,即 Id 为 0,则插入语句成功。在现有实体上调用 Save 时,出现异常:

System.InvalidCastException occurred
  HResult=-2147467262
  Message=Failed to convert parameter value from a TimeSpan to a DateTime.
  Source=TechTalk.SpecFlow
  StackTrace:
       at System.Data.SqlClient.SqlParameter.CoerceValue(Object value, MetaType destinationType, Boolean& coercedToDataFeed, Boolean& typeChanged, Boolean allowStreaming)
       at System.Data.SqlClient.SqlParameter.GetCoercedValue()
       at System.Data.SqlClient.SqlParameter.Validate(Int32 index, Boolean isCommandProc)
       at System.Data.SqlClient.SqlCommand.BuildParamList(TdsParser parser, SqlParameterCollection parameters)
       at System.Data.SqlClient.SqlCommand.BuildExecuteSql(CommandBehavior behavior, String commandText, SqlParameterCollection parameters, _SqlRPC& rpc)
       at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async, Int32 timeout, Task& task, Boolean asyncWrite)
       at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, TaskCompletionSource`1 completion, Int32 timeout, Task& task, Boolean asyncWrite)
       at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, String methodName, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite)
       at System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
       at Dapper.SqlMapper.ExecuteCommand(IDbConnection cnn, IDbTransaction transaction, String sql, Action`2 paramReader, Object obj, Nullable`1 commandTimeout, Nullable`1 commandType) in c:\Dev\Dapper\Dapper NET40\SqlMapper.cs:line 2034
       at Dapper.SqlMapper.Execute(IDbConnection cnn, String sql, Object param, IDbTransaction transaction, Nullable`1 commandTimeout, Nullable`1 commandType) in c:\Dev\Dapper\Dapper NET40\SqlMapper.cs:line 730
       at DapperExtensions.DapperImplementor.Update[T](IDbConnection connection, T entity, IDbTransaction transaction, Nullable`1 commandTimeout) in c:\Data\Projects\Nuget Projects\DapperExtensions\DapperExtensions\DapperImplementor.cs:line 140

我安装了最新的 NuGet 版本的 Dapper 和 DapperExtensions。

为什么插入成功,而更新不成功?有我可以使用的解决方法吗?

到目前为止,我已经手动创建了要调用的更新 sql,但这远非理想。这个简单的例子有效:

_connection.Execute("update Entity set Duration=@Duration, ... where Id=@Id",
    new {
        e.Id,
        e.Duration,
        ...
    });
4

0 回答 0