我正在处理正在异步获取DataReader的DAL。
我想编写一个方法将DataReader转换为DataSet。它需要处理不同的模式,以便这一个方法将处理我的所有获取需求。
P.S。我正在异步填充SQLDataReader,请不要给出摆脱DataReader的答案。
答案 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);