ADO.NET - Ошибка чтения данных - PullRequest
0 голосов
/ 10 января 2011

Я пытаюсь отобразить данные из столбца в моей базе данных в мое расширенное текстовое поле, но я путаюсь между 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 Ответ

2 голосов
/ 10 января 2011

У каждого из ваших фрагментов есть проблема.

Для реализации адаптера данных вы предоставили следующее:

        SqlCommand cmd = new SqlCommand(SQL, conn);
        conn.Open();

        DataTable dt = new DataTable();
        da.Fill(dt); //ERROR

Вы не связываете свой объект SqlCommand с вашим DataAdapter, поэтому он не знает, как заполнить ваш 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();
        }
...