ADO.NET - Ошибка чтения данных
Я пытаюсь отобразить данные из столбца в моей базе данных в мое расширенное текстовое поле, но я путаюсь между DataSet и DataReader - я знаю, что большая часть кода ниже верна, я просто получаю две строки, содержащие ошибки, и я ' Я не уверен, почему:
// Create a connection string
string ConnectionString = ("Provider=Microsoft.ACE.OLEDB.12.0;Data Source= C:\\Documents and Settings\\Harley\\Desktop\\Test.accdb");
string SQL = "SELECT * FROM Paragraph";
// create a connection object
SqlConnection conn = new SqlConnection(ConnectionString);
// Create a command object
SqlCommand cmd = new SqlCommand(SQL, conn);
conn.Open();
DataTable dt = new DataTable();
da.Fill(dt); //ERROR
// Call ExecuteReader to return a DataReader
SqlDataReader reader = cmd.ExecuteReader();
foreach(DataRow reader in dsRtn) //ERROR
{
richTextBox = richTextBox.Text + reader[0].ToString();
}
//Release resources
reader.Close();
conn.Close();
}
1 ответ
Решение
У каждого из ваших фрагментов есть проблема.
Для реализации адаптера данных вы предоставили следующее:
SqlCommand cmd = new SqlCommand(SQL, conn);
conn.Open();
DataTable dt = new DataTable();
da.Fill(dt); //ERROR
Вы не связываете свой объект SqlCommand с вашим Data Adapter, поэтому он не знает, как заполнить ваш DataTable.
Что касается вашей реализации Data Reader,
// Call ExecuteReader to return a DataReader
SqlDataReader reader = cmd.ExecuteReader();
foreach(DataRow reader in dsRtn) //ERROR
{
richTextBox = richTextBox.Text + reader[0].ToString();
}
вы используете DataReader неправильно попробуйте это:
// Call ExecuteReader to return a DataReader
SqlDataReader reader = cmd.ExecuteReader();
while( reader.Read() )
{
richTextBox = richTextBox.Text + reader[0].ToString();
}