Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
Иван Пивнев
0 / 0 / 0
Регистрация: 14.04.2017
Сообщений: 6
1

ExecuteNonQuery: Свойство Connection не инициализировано

13.05.2018, 16:59. Просмотров 823. Ответов 7
Метки нет (Все метки)

У меня ошибка при использовании кнопки. Можете помочь?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
private void button12_Click(object sender, EventArgs e)
        {
            var str1 = new System.Data.OleDb.OleDbConnection();
            // str1.ConnectionString = "Dsn=kk;dbq=E:/5901/Пивнев/Microsoft Access База данных.mdb;driverid=25;fil=MS Access;maxbuffersize=2048;pagetimeout=5;pwd=masterkey;uid=admin";
            str1.ConnectionString = Properties.Settings.Default.Microsoft_Access_База_данныхConnectionString1;
            str1.Open();
            if (label63.Visible)
                label63.Visible = false;
 
            if (!string.IsNullOrEmpty(textBox49.Text) && !string.IsNullOrWhiteSpace(textBox49.Text))
            {
                OleDbCommand command = new OleDbCommand("DELETE FROM [Студент] WHERE [ID_S]=@ID_S", oleConnection);
 
                command.Parameters.AddWithValue("ID_S", textBox49);
                command.ExecuteNonQuery();
 
            }
            else
            {
                label63.Visible = true;
                label63.Text = "Поля должны быть заполнены!";
            }
        }
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.05.2018, 16:59
Ответы с готовыми решениями:

ExecuteNonQuery: Свойство Connection не инициализировано
как исправить ошибку, не подскажите??? private void button1_Click_1(object sender, EventArgs e)...

ExecuterReader: Свойство Connection не инициализировано
Здравствуйте, помогите,пожалуйста SqlConnection con = new SqlConnection(connectionString); ...

ExecuteReader: Свойство Connection не инициализировано
При обработке, выскакивает ошибка. Подскажите пожалуйста, что я неправильно делаю protected void...

Свойство Connection для DeleteCommand не инициализировано
Запускаю проект, выделяю полностью строку, удаляю ее с помощью кнопки "del", сохраняю изменения -...

Добавление в базу данных. Не инициализировано свойство connection
Хочу добавить записи в БД но получается следующее: Укорачиваю записи и получается следующее: ...

7
meridbt
129 / 107 / 78
Регистрация: 30.07.2013
Сообщений: 414
Завершенные тесты: 1
13.05.2018, 21:32 2
Иван Пивнев,

А какое значение присваивается переменной oleConnection?
1
Иван Пивнев
0 / 0 / 0
Регистрация: 14.04.2017
Сообщений: 6
14.05.2018, 08:14  [ТС] 3
это подключение, по моему
C#
1
2
3
4
5
6
7
8
    public partial class Form1 : Form
    {
      
        OleDbConnection oleConnection;
        public Form1()
        {
            InitializeComponent();
        }
0
meridbt
129 / 107 / 78
Регистрация: 30.07.2013
Сообщений: 414
Завершенные тесты: 1
14.05.2018, 08:55 4
Иван Пивнев,

переменная объявлена, но ей не присвоено значение.
Предполагаю что должно выполняться подключение к
C#
1
Properties.Settings.Default.Microsoft_Access_База_данныхConnectionString1
Если да, то можно инициализировать command так:

C#
1
2
oleConnection = str1;
OleDbCommand command = new OleDbCommand("DELETE FROM [Студент] WHERE [ID_S]=@ID_S", oleConnection);
или так

C#
1
OleDbCommand command = new OleDbCommand("DELETE FROM [Студент] WHERE [ID_S]=@ID_S", str1);
1
Иван Пивнев
0 / 0 / 0
Регистрация: 14.04.2017
Сообщений: 6
14.05.2018, 09:31  [ТС] 5
сейчас попробую

Добавлено через 6 минут
да, кнопки теперь работают, но обновление эту же ошибку выдаёт
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
private void обновитьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            listBox1.Items.Clear();
            OleDbDataReader sqlReader = null;
            OleDbDataReader sqlReader2 = null;
            OleDbDataReader sqlReader3 = null;
            OleDbDataReader sqlReader4 = null;
            OleDbCommand command1 = new OleDbCommand("Select * FROM[Студент]", str1);
            OleDbCommand command2 = new OleDbCommand("Select * FROM[Работодатель]", str1);
            OleDbCommand command3 = new OleDbCommand("Select * FROM[Практические_занятия]", str1);
            OleDbCommand command4 = new OleDbCommand("Select * FROM[Предприятие]", str1);
            try
            {
                sqlReader = command1.ExecuteReader();
                sqlReader2 = command2.ExecuteReader();
                sqlReader3 = command3.ExecuteReader();
                sqlReader4 = command4.ExecuteReader();
 
                while (sqlReader.Read())
                {
                    listBox1.Items.Add(Convert.ToString(sqlReader["Id_S"]) + "      " + Convert.ToString(sqlReader["Фамилия"]) + "      " + Convert.ToString(sqlReader["Имя"]) + "      " + Convert.ToString(sqlReader["Курс"]) + "      " + Convert.ToString(sqlReader["ID_Pr"]));
                    listBox2.Items.Add(Convert.ToString(sqlReader2["Id_Z"]) + "      " + Convert.ToString(sqlReader2["Фамилия"]) + "      " + Convert.ToString(sqlReader2["Имя"]) + "      " + Convert.ToString(sqlReader2["Город"]) + "      " + Convert.ToString(sqlReader2["ID_Pr"]));
                    listBox3.Items.Add(Convert.ToString(sqlReader3["Id_Pr"]) + "      " + Convert.ToString(sqlReader3["Название_предприятия"]) + "      " + Convert.ToString(sqlReader3["Город"]));
                    listBox4.Items.Add(Convert.ToString(sqlReader4["Id_P"]) + "      " + Convert.ToString(sqlReader4["Имя_Занятия"]) + "      " + Convert.ToString(sqlReader4["Часы"]) + "      " + Convert.ToString(sqlReader4["Симестр"]));
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message.ToString(), ex.Source.ToString(), MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            finally
            {
                if (sqlReader != null)
                    sqlReader.Close();
                if (sqlReader2 != null)
                    sqlReader2.Close();
                if (sqlReader3 != null)
                    sqlReader3.Close();
                if (sqlReader4 != null)
                    sqlReader4.Close();
            }
        }
0
meridbt
129 / 107 / 78
Регистрация: 30.07.2013
Сообщений: 414
Завершенные тесты: 1
14.05.2018, 09:36 6
Иван Пивнев,

str1 это локальная переменная, которая видна только в методе button12_Click
1
Иван Пивнев
0 / 0 / 0
Регистрация: 14.04.2017
Сообщений: 6
14.05.2018, 09:47  [ТС] 7
то есть, мне нужно сделать её глобальной?

Добавлено через 10 минут
о, что то получилось, но теперь ошибка в том, что при обновлении отсутствуют данные для строки или столбца. И оставляет только одну первую строку таблицы.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
private void обновитьToolStripMenuItem_Click(object sender, EventArgs e)
        {
            var str1 = new System.Data.OleDb.OleDbConnection();
            // str1.ConnectionString = "Dsn=kk;dbq=E:/5901/Пивнев/Microsoft Access База данных.mdb;driverid=25;fil=MS Access;maxbuffersize=2048;pagetimeout=5;pwd=masterkey;uid=admin";
            str1.ConnectionString = Properties.Settings.Default.Microsoft_Access_База_данныхConnectionString1;
            str1.Open();
            listBox1.Items.Clear();
            OleDbDataReader sqlReader = null;
            OleDbDataReader sqlReader2 = null;
            OleDbDataReader sqlReader3 = null;
            OleDbDataReader sqlReader4 = null;
            OleDbCommand command1 = new OleDbCommand("Select * FROM[Студент]", str1);
            OleDbCommand command2 = new OleDbCommand("Select * FROM[Работодатель]", str1);
            OleDbCommand command3 = new OleDbCommand("Select * FROM[Практические_занятия]", str1);
            OleDbCommand command4 = new OleDbCommand("Select * FROM[Предприятие]", str1);
            try
            {
                sqlReader = command1.ExecuteReader();
                sqlReader2 = command2.ExecuteReader();
                sqlReader3 = command3.ExecuteReader();
                sqlReader4 = command4.ExecuteReader();
 
                while (sqlReader.Read())
                {
                    listBox1.Items.Add(Convert.ToString(sqlReader["Id_S"]) + "      " + Convert.ToString(sqlReader["Фамилия"]) + "      " + Convert.ToString(sqlReader["Имя"]) + "      " + Convert.ToString(sqlReader["Курс"]) + "      " + Convert.ToString(sqlReader["ID_Pr"]));
                    listBox2.Items.Add(Convert.ToString(sqlReader2["Id_Z"]) + "      " + Convert.ToString(sqlReader2["Фамилия"]) + "      " + Convert.ToString(sqlReader2["Имя"]) + "      " + Convert.ToString(sqlReader2["Город"]) + "      " + Convert.ToString(sqlReader2["ID_Pr"]));
                    listBox3.Items.Add(Convert.ToString(sqlReader3["Id_Pr"]) + "      " + Convert.ToString(sqlReader3["Название_предприятия"]) + "      " + Convert.ToString(sqlReader3["Город"]));
                    listBox4.Items.Add(Convert.ToString(sqlReader4["Id_P"]) + "      " + Convert.ToString(sqlReader4["Имя_Занятия"]) + "      " + Convert.ToString(sqlReader4["Часы"]) + "      " + Convert.ToString(sqlReader4["Симестр"]));
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message.ToString(), ex.Source.ToString(), MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            finally
            {
                if (sqlReader != null)
                    sqlReader.Close();
                if (sqlReader2 != null)
                    sqlReader2.Close();
                if (sqlReader3 != null)
                    sqlReader3.Close();
                if (sqlReader4 != null)
                    sqlReader4.Close();
            }
        }
0
meridbt
129 / 107 / 78
Регистрация: 30.07.2013
Сообщений: 414
Завершенные тесты: 1
14.05.2018, 09:51 8
Лучший ответ Сообщение было отмечено Иван Пивнев как решение

Решение

Иван Пивнев,

с точки зрения ресурсов если подключение к БД требуется эпизодически, выгодно пользоваться IDisposable конструкцией:

C#
1
2
3
4
5
using (OleDbConnection oleConnection = new OleDbConnection(Properties.Settings.Default.Microsoft_Access_База_данныхConnectionString1) )
{
    // выполняем работу с БД
}
// oleConnection высвобождает ресурсы
1
14.05.2018, 09:51
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.05.2018, 09:51

System.InvalidOperationException: "ExecuteReader: Свойство Connection не инициализировано."
static void Main(string args) { String connection = @"Data...

Свойство ConnectionString не инициализировано
Не понимаю почему не работает помогите using System; using System.Collections.Generic; using...

Свойство ConnectionString не инициализировано
Проконсультируйте пожалуйста, кто может а то, я на этой неделе начал разбираться, и возникло уйма...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru