我可以在ValueTuple中返回泛型类型吗?

时间:2018-04-20 20:50:02

标签: c# generics valuetuple

这里有一些代码示例。我收到错误"无法隐式转换类型' string'到''"

public ValueTuple<string, T> TestMethod<T>()
{
    return ("test", "");
}

我该怎么做呢?这是否超出了ValueTuple的限制?

我正在使用的实际代码示例

public ValueTuple<bool, T> RunSelectAllCommand<T>(MySqlCommand command, 
    List<MySqlParameter> parameterCollection) where T : class
{
    using (MySqlConnection conn = new MySqlConnection(connectionString))
    using (var cmd = conn.CreateCommand())
    {
        conn.Open();            
        cmd.CommandText = command.CommandText;

        // if parameters for query are specified, add them here.
        if (parameterCollection != null)
        {
            cmd.Parameters.AddRange(parameterCollection.ToArray());
        }
        using (var reader = cmd.ExecuteReader())
        {
            // We're selecting all keys from registration database 
            // this is probably a horrible design. oh, well...
            if (typeof(T) == typeof(KeyRow))
            {
                List<KeyRow> data = new List<KeyRow>();
                while (reader.Read())
                {
                    data.Add(new KeyRow(reader["keycode"].ToString(), 
                        reader["apikey"].ToString(), 
                        reader["ipaddress"].ToString(),
                        DateTime.Parse(reader["date"].ToString()), 
                        reader["hwid"].ToString() ?? ""));
                }

                return (true, data as T);
            }
        }
    }

    return (false, null);
}

1 个答案:

答案 0 :(得分:1)

使用您的示例,我将以下内容作为如何执行您尝试执行的操作的示例。这使用通用实现方法来重用您可能返回的各种类型,这是一种非泛型方法,用于公开返回这些类型。

public ValueTuple<bool, List<KeyRow>> RunSelectAllKeyRowCommand(IDbCommand command, List<IDataParameter> parameterCollection) =>
    RunSelectAllCommandImpl<KeyRow>(command, 
                                    parameterCollection,
                                    reader => new KeyRow(reader["keycode"].ToString(), reader["apikey"].ToString(), reader["ipaddress"].ToString(), DateTime.Parse(reader["date"].ToString()), reader["hwid"].ToString() ?? ""));

private ValueTuple<bool, List<T>> RunSelectAllCommandImpl<T>(IDbCommand command, List<IDataParameter> parameterCollection, Func<IDataReader, T> mapper) where T : class
{
    using (IDbConnection conn = GetDataConnection())
    using (var cmd = conn.CreateCommand())
    {
        conn.Open();
        cmd.CommandText = command.CommandText;

        foreach(var parameter in parameterCollection) // if parameters for query are specified, add them here.
            cmd.Parameters.Add(parameter);

        using (var reader = cmd.ExecuteReader())
        {
            List<T> data = new List<T>();

            while (reader.Read())
                data.Add(mapper(reader));

            return (true, data);
        }
    }

    return (false, null);
}