我想在DataSet中实现像RecordSet中MoveNext类似的逐条访问数据功能,但却怎么也实现不了。

解决方案 »

  1.   

    一个就是通过IDbCommand.ExecuteReader 方法
    直接返回IDataReader.比如:
    SqlDataReader readr = SqlCommand.ExecuteReader();另一个就是通过2.0的新功能。
    DataTableReader dtReader = DataTable.CreateDataReader ();
    =====================
    private static void TestCreateDataReader(DataTable dt)
    {
        // Given a DataTable, retrieve a DataTableReader
        // allowing access to all the tables' data:
        using (DataTableReader reader = dt.CreateDataReader())
        {
            do
            {
                if (!reader.HasRows)
                {
                    Console.WriteLine("Empty DataTableReader");
                }
                else
                {
                    PrintColumns(reader);
                }
                Console.WriteLine("========================");
            } while (reader.NextResult());
        }
    }private static DataTable GetCustomers()
    {
        // Create sample Customers table, in order
        // to demonstrate the behavior of the DataTableReader.
        DataTable table = new DataTable();    // Create two columns, ID and Name.
        DataColumn idColumn = table.Columns.Add("ID", typeof(int));
        table.Columns.Add("Name", typeof(string));    // Set the ID column as the primary key column.
        table.PrimaryKey = new DataColumn[] { idColumn };    table.Rows.Add(new object[] { 1, "Mary" });
        table.Rows.Add(new object[] { 2, "Andy" });
        table.Rows.Add(new object[] { 3, "Peter" });
        table.Rows.Add(new object[] { 4, "Russ" });
        return table;
    }private static void PrintColumns(DataTableReader reader)
    {
        // Loop through all the rows in the DataTableReader
        while (reader.Read())
        {
            for (int i = 0; i < reader.FieldCount; i++)
            {
                Console.Write(reader[i] + " ");
            }
            Console.WriteLine();
        }
    }根据情况楼主可以选择一种实现.