通过http发送ExecuteReader结果的最佳方式

时间:2015-02-16 07:21:23

标签: c# sql rest http executereader

最好的方法是什么,将ADO.NETs ExecuteReader的结果通过http发送给客户端(客户端当然会提取数据)。

我不想将结果加载到List<Dictionary<string, object>>序列化它等等,因为这似乎产生了很多问题。

是否有方法,通过http将数据作为二进制格式发送?

谢谢!

1 个答案:

答案 0 :(得分:1)

我认为最好的方法是使用表字段作为类成员构建自定义类,然后将每行作为新实例发送到plain数组:

public class Car
{
    public string Model { get; set; }
    public int Price { get; set; }
}

public void Foo()
{
    string strSQL = "Select * From Cars";

    List<Car> cars = new List<Car>();
    //...initialize connection, Command, etc...
    while (reader.Read())
    {
        cars.Add(new Car {
            Model = reader["Model"] + "", 
            Price = (int)reader["Price"]
        });
    }
    //...send cars.ToArray() over to client...
}

这样,您只需要发送所需的数据,而且开销为零。

如果您想使其灵活并支持任何表结构,您还需要更多的类。我能想到的最基本的东西就是这样的课程:

public class BasicField
{
    public string Name { get; set; }
    public object Value { get; set; }
}

public class BasicRow
{
    public BasicField[] Fields { get; set; }
}

public class BasicTable
{
    public BasicRow[] Rows { get; set; }

    public static BasicTable Parse(DataTable table)
    {
        string[] fieldNames = table.Columns.OfType<DataColumn>().ToList().ConvertAll(c => c.Caption).ToArray();
        List<BasicRow> basicRows = table.Rows.OfType<DataRow>().ToList().ConvertAll(dataRow =>
        {
            List<BasicField> fields = new List<BasicField>();
            for (int i = 0; i < dataRow.ItemArray.Length; i++)
                fields.Add(new BasicField
                {
                    Name = fieldNames[i], 
                    Value = dataRow.ItemArray[i]
                });
            return new BasicRow
            {
                Fields = fields.ToArray()
            };
        });
        return new BasicTable
        {
            Rows = basicRows.ToArray()
        };
    }
}

然后要使用它,需要这样的代码:

BasicTable basicTable;
string strSQL = "Select * From Cars";
using (DataTable table = new DataTable())
{
    using (SqlDataAdapter adapter = new SqlDataAdapter(strSQL, connection))
    {
        adapter.Fill(table);
    }
    basicTable = BasicTable.Parse(table);
}

你可以将basicTable发送给客户端,由最小的原始成员组成,它应该有最小的开销。