Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/21: Рейтинг темы: голосов - 21, средняя оценка - 5.00
3 / 3 / 2
Регистрация: 31.10.2017
Сообщений: 35

Проверка на сохранение перед закрытием приложения

22.12.2017, 10:30. Показов 4281. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток
Ситуация такая:

Приложение c# winform подключенное к sql серверу.

Как сделать проверку перед закрытие приложения на сохранение изменений(если таковые были) в базе?

как в том же excel допустим:
Вы хотите сохранить изменения?
Сохранить--Выйти без сохранения--Отмена

Но excel выдает этот вопрос только при внесении изменений в файл. хочу так же
Подскажите ^_^
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.12.2017, 10:30
Ответы с готовыми решениями:

Сохранение информации перед закрытием
Есть форма. Есть какие-то переменные, которые задаются во время работы приложения. Нужно, чтобы при закрытии значения сохранялись. Потом...

Запрос на сохранение изменений перед закрытием
Добрый вечер. Нагуглить ничего не вышло, поэтому спрашиваю тут. Как отследить изменения при выполнении программы с крайнего сохранения? На...

Нужно ли вызывать Dispose() перед закрытием приложения
Всем привет! Есть PictureBox со свойством Image. Насколько я понял, если в программе динамически меняется изображение в PictureBox, перед...

4
 Аватар для Павлик Морозов
138 / 137 / 42
Регистрация: 26.10.2012
Сообщений: 443
22.12.2017, 11:30
ZanydaZanydnaya, отслеживайте изменения данных в Вашей модели. Например, подписываясь на события связанных компонентов, отображающих данные. Перед закрытием приложения проверяйте наличие изменений в модели. Если есть, то сохраняйте их в бд.
1
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
22.12.2017, 12:15
Лучший ответ Сообщение было отмечено ZanydaZanydnaya как решение

Решение

Павлик Морозов, Была у меня такая же задача. Думал пойти по Вашей логике (события изменения в контролах), но потом отказался.
Для примера:
в текстбоксе с БД отображается число 2, пользователь поменял на 3, потом поменял обратно на 2. Событие сработало, но изменений не было - нужно ли сохранять такое? - Я для себя (субъективно ИМХО) решил что не стоит дергать сиквел для тех данных, что физически не поменялись (хоть логически и были изменения). Поэтому я в момент закрытия формы делал проверку - текущее состояние модели != скачанное с БД по все своим полям, а по таблицам - делал проверку на GetChanges(). Для пары десятков контролов и таблиц - проверка занимала считанные милисекунды - меня устроило.
1
3 / 3 / 2
Регистрация: 31.10.2017
Сообщений: 35
22.12.2017, 12:27  [ТС]
Пока не знаю как сделать, но буду пробовать! спасибо!
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
22.12.2017, 13:13
Если совсем по простому - есть класс-модель, в нем есть, допустим для упрощения, 2 поля - типа int и типа string.
Я в классе организовал свой метод Equals() для 2-ух экземпляров этого класса, в котором сравнивал поштучно все свои поля.
Далее при приёме данных с сиквела маппил их в 2 экземпляра класса, old и new, new связывал с формой, а old оставался как есть, загруженый с БД. При закрытии формы просто сравнивал эти 2 экземпляра между собой, если есть различия - значит изменения были, если нет - то их не было физически. От этого строил дальнейшую логику.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.12.2017, 13:13
Помогаю со студенческими работами здесь

Проверка содержимого TextBox перед закрытием формы
Есть форма с множеством текстбоксов, она заполняется и нажимается кнопка "закрыть". Нужно проверить введены ли в каждом тексбоксе...

Запрос перед закрытием приложения
Как сделать так, чтобы после попытки закрытия программы появлялось диалоговое окно, но окна самой программы при этом не закрывались?...

Действие перед закрытием приложения
Мне нужно, что бы перед закрытием приложения информация из TextBox записалась в файл. Как записать в файл я поняла ...

Проверка пустых полей перед закрытием формы
Доброго времени суток уважаемые форумчане! Нужна Ваша помощь в реализации следующей задумки: Имеем три таблицы, поля которых...

Проверка полей формы перед закрытием окна Swing
Добрый день, уважаемые коллеги :senor: Натолкните, пожалуйста, на мысль: как реализовать проверку перед закрытием окна Swing, если...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru