通用实现中的表值的Dapper参数

时间:2015-04-09 08:42:49

标签: c# asp.net-mvc visual-studio dapper

关注帖子 Using Dapper.TVP TableValueParameter with other parameters 我已经能够执行表值参数但我的问题是关于其实现的一部分。程序似乎有效,但我怎样才能使这个实现更通用?使用'new {}'在DynamicParameters中添加参数是非常专业的实现。我希望能够指定我的参数名称..例如

public IEnumerable<TCustomEntity> SqlQuery<TCustomEntity>(string query, IDictionary<string, object> parameters,
            CommandType commandType) where TCustomEntity : class
        {
            DataTable dt;
            DynamicParameters dp;
            var sqlConnection = _context.Database.Connection;
            try
            {

                if (sqlConnection.State == ConnectionState.Closed)
                {
                    sqlConnection.Open();
                }


                var dynamicParameters = new DynamicParameters();
                if (parameters != null)
                    foreach (var parameter in parameters)
                    {

                        if (parameter.Value is int)
                            dynamicParameters.Add(parameter.Key, parameter.Value, DbType.Int32);
                        else if (parameter.Value is string)
                            dynamicParameters.Add(parameter.Key, parameter.Value.ToString(), DbType.String);
                        else if (parameter.Value is DateTime)
                            dynamicParameters.Add(parameter.Key, parameter.Value, DbType.DateTime);
                        else if (parameter.Value is Decimal)
                            dynamicParameters.Add(parameter.Key, parameter.Value, DbType.Decimal);
                         else if (parameter.Value is DataTable)
                         {
                             dt = (DataTable)parameter.Value;
                             dt.SetTypeName(dt.TableName);
                             var parameterName = parameter.Key;

                             dp = new DynamicParameters(new { TVPName = dt });
                             // Here i want TVPName replaced with parameterName/parameter.Key but it doesn't seem possible
                             dynamicParameters.AddDynamicParams(dp);



                         }
                        else
                         dynamicParameters.Add(parameter.Key,  parameter.Value);
                    }
                var test = sqlConnection.Query<TCustomEntity>(query, dynamicParameters, commandType: commandType);
                return test;
            }
            finally
            {
                sqlConnection.Close();
            }
        }

任何建议我如何通过使参数名称更通用来继续解决这个问题?如果没有,每次使用Table值参数

时都会进行专门的实现

1 个答案:

答案 0 :(得分:4)

对我来说,显然任何是必要的,因为:

  1. DynamicParameters非常满意TVP作为直接元素,
  2. 显示的所有数据类型都将自动处理
  3. dapper与词典愉快地合作
  4. dapper已经打开并且如果在调用时没有打开则适当地关闭连接
  5. 在我看来,这里唯一有趣的步骤是SetTypeName,可以这样做:

    foreach(object val in parameters.Values)
    {
        if(val is DataTable) {
            var dt = (DataTable)val;
            dt.SetTypeName(dt.TableName);
        }
    }
    

    然后将原始parameters对象传递到:

    return sqlConnection.Query<TCustomEntity>(query, parameters, commandType: commandType);
    

    只留下:

    public IEnumerable<TCustomEntity> SqlQuery<TCustomEntity>(string query,
        IDictionary<string, object> parameters, // suggestion: default to null
        CommandType commandType // suggestion: default to CommandType.Text
    ) where TCustomEntity : class
    {
        var sqlConnection = _context.Database.Connection;
    
        if (parameters != null) {
            foreach (object val in parameters.Values) {
                if (val is DataTable) {
                    var dt = (DataTable)val;
                    // suggestion: might want to only do if dt.GetTypeName() is null/""
                    dt.SetTypeName(dt.TableName);
                }
            }
        }
    
        return sqlConnection.Query<TCustomEntity>(query, parameters,
            commandType: commandType);
    }