Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/47: Рейтинг темы: голосов - 47, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 14.04.2017
Сообщений: 6

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

13.05.2018, 16:59. Показов 8809. Ответов 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)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.05.2018, 16:59
Ответы с готовыми решениями:

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

Свойство SelectCommand.Connection не инициализировано
При фильтрации DataGrid через ComboBox выдается следующая ошибка Fill: Свойство SelectCommand.Connection не инициализировано. private...

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

7
182 / 145 / 94
Регистрация: 30.07.2013
Сообщений: 579
13.05.2018, 21:32
Иван Пивнев,

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

переменная объявлена, но ей не присвоено значение.
Предполагаю что должно выполняться подключение к
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  [ТС]
сейчас попробую

Добавлено через 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
182 / 145 / 94
Регистрация: 30.07.2013
Сообщений: 579
14.05.2018, 09:36
Иван Пивнев,

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

Добавлено через 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
182 / 145 / 94
Регистрация: 30.07.2013
Сообщений: 579
14.05.2018, 09:51
Лучший ответ Сообщение было отмечено Иван Пивнев как решение

Решение

Иван Пивнев,

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

C#
1
2
3
4
5
using (OleDbConnection oleConnection = new OleDbConnection(Properties.Settings.Default.Microsoft_Access_База_данныхConnectionString1) )
{
    // выполняем работу с БД
}
// oleConnection высвобождает ресурсы
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.05.2018, 09:51
Помогаю со студенческими работами здесь

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

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

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

System.InvalidOperationException: "Fill: Свойство SelectCommand.Connection не инициализировано."
У меня есть класс,который имеет в себе ф-ции по подключению к базе данных. Есть так же форма , по нажатию на кнопку которой должна...

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


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru