Füllen eines DataSets mit mehreren Tabellen mithilfe eines DataReaders
Wenn Sie mit einem DataSet arbeiten, das mehrere Tabellen mit Eins-zu-vielen-Beziehungen enthält, Es ist möglich, es mit einem DataReader zu füllen. Der Standardansatz, einen einzelnen DataReader zu verwenden, erfasst jedoch möglicherweise nicht Daten aus allen Tabellen.
Um diese Einschränkung zu überwinden, können Sie den folgenden Ansatz verwenden:
using System.Data; using System.Data.SqlClient; using System.IO; namespace SampleApp { public class DataSetWithTables { private SqlConnection connection; public DataSet SelectOne(int id) { DataSet result = new DataSet(); string query = @"select * from table1; select * from table2 where table1_id = @ID;"; using (connection = new SqlConnection("ConnectionString")) { connection.Open(); using (SqlCommand command = new SqlCommand(query, connection)) { command.Parameters.AddWithValue("ID", id); using (SqlDataReader reader = command.ExecuteReader()) { DataTable table1 = new DataTable("Table1"); DataTable table2 = new DataTable("Table2"); table1.Load(reader); if (reader.NextResult()) { table2.Load(reader); } result.Tables.Add(table1); result.Tables.Add(table2); } } connection.Close(); } return result; } } }
In diesem Ansatz:
Das obige ist der detaillierte Inhalt vonWie fülle ich ein DataSet mit einem DataReader effizient mit mehreren Tabellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!