• 🔥 Бесплатный курс от Академии Кодебай: «Анализ защищенности веб-приложений»

    🛡 Научитесь находить и использовать уязвимости веб-приложений.
    🧠 Изучите SQLi, XSS, CSRF, IDOR и другие типовые атаки на практике.
    🧪 Погрузитесь в реальные лаборатории и взломайте свой первый сайт!
    🚀 Подходит новичкам — никаких сложных предварительных знаний не требуется.

    Доступ открыт прямо сейчас Записаться бесплатно

Datatable+datagridview

  • Автор темы Автор темы Balda
  • Дата начала Дата начала
B

Balda

MS VS Studio 2008 C#
Данные из БД загружаются в DataTable, к-й служит источником данных для DataGridView.
При первой загрузке данных в таблицу всё хорошо.
Но если перед следующей загрузкой данных:
Код:
table.Clear();
table.Columns.Clear();
SqlDataAdapter1.Fill(table);
пользователь отсортирует строки в гриде по какому-либо столбцу, то вылетает сообщение вида: "Object is not set to an instance of an object".

Если же изменить код так:
Код:
table.Reset();
SqlDataAdapter1.Fill(table);
то таблица заполняется данными и привязка таблицы к гриду сохраняется, но почему-то не отображаются строки в гриде.

Вопрос: почему так и что с этим делать?
 
Попробуйте очистить DataSource у Вашего DataGridView перед обновлением данных.

Код:
DataGridView1.DataSource = null;
table.Clear();
table.Columns.Clear();
SqlDataAdapter1.Fill(table);
DataGridView1.DataSource = table;
 
Нет. Не в привязке дело.
Ошибка возникает на этой строке:
Код:
SqlDataAdapter1.Fill(table);
В принципе проблема решана так: создаю каждый раз новую таблицу.
Тогда никаких ошибок не наблюдается.
 
Мы в соцсетях:

Взломай свой первый сервер и прокачай скилл — Начни игру на HackerLab