从SQLDataReader填充DataSet的最佳方法

时间:2009-02-04 05:18:14

标签: sql dataset sqldatareader

我正在处理正在异步获取DataReader的DAL。

我想编写一个方法将DataReader转换为DataSet。它需要处理不同的模式,以便这一个方法将处理我的所有获取需求。

P.S。我正在异步填充SQLDataReader,请不要给出摆脱DataReader的答案。

3 个答案:

答案 0 :(得分:14)

DataTable.load()可用于通用方法。

do {
    var table = new DataTable();
    table.Load(reader);
    dataset.Tables.Add(table);
} while(!reader.IsClosed);

答案 1 :(得分:9)

试试DataSet.Load()。它有几个带IDataReader的重载。

答案 2 :(得分:0)

如果由于某种原因Load方法失败,这是一种手动方式:

                    DataTable dt = new DataTable();
                    dt = sdr.GetSchemaTable();
                    //dt.Constraints.Clear();
                    //dt.PrimaryKey = null;
                    //dt.BeginLoadData();
                    if (sdr.HasRows)
                    {
                        DataRow row;
                        while (sdr.Read())
                        {
                            row = dt.NewRow();
                            sdr.GetValues(row.ItemArray);
                            dt.Rows.Add(row);
                        }

另一种方法是使用SqlTableAdapter:

var adapter = new SqlDataAdapter(command);
DataSet ds = new DataSet();
adapter.Fill(ds);