|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
|
Опции темы | Поиск в этой теме |
06.02.2013, 09:22 | #1 |
Пользователь
Регистрация: 02.04.2012
Сообщений: 49
|
Ошибка при повторном Insert после CancelUpdates
Добрый день!
Такая ситуация: 1. Вызываю pFIBDataSet.Insert; 2. Открывается форма. Если в ней нажать Отмена, вызывается pFIBDataSet.CancelUpdates. 3. Следующий вызов Insert выходит в ошибку Как будто CancelUpdates не отрабатывает... В чем может быть проблема? |
06.02.2013, 11:17 | #2 |
Участник клуба
Регистрация: 19.12.2007
Сообщений: 1,100
|
а ошибка то какая?
и что в InsertSQL.Text ?
На форуме: Помогаю за спасибо
ICQ\Skype: Это моё личное время ... |
06.02.2013, 11:30 | #3 |
Пользователь
Регистрация: 02.04.2012
Сообщений: 49
|
Стандартная, дельфийская (во вложении)
в InsertSQL вот что: Код:
P.S. Проверил вот что - После CancelUpdates pFIBDataset.State in dsEditModes ((( Последний раз редактировалось Romowski; 06.02.2013 в 11:39. |
06.02.2013, 11:49 | #4 |
Старожил
Регистрация: 09.01.2008
Сообщений: 26,229
|
судя по ошибке, это не c запросом проблема..
рискну предположить, что при закрытии формы какой-то из объектов уничтожается (как вариант, pFIBDataSet ). При повторном обращении - не создаётся. Попытка обращения к несозданному объекту и даёт access violation... |
06.02.2013, 11:52 | #5 | |
Участник клуба
Регистрация: 19.12.2007
Сообщений: 1,100
|
Цитата:
а на тему ошибки, да, Serg прав, запрос тут не приделах. показывай под кнопок "отмены" и "добавления". и еще, почему бы не делать pFIBDataSet.Cancel вместо pFIBDataSet.CancelUpdates ?
На форуме: Помогаю за спасибо
ICQ\Skype: Это моё личное время ... |
|
06.02.2013, 12:15 | #6 |
Пользователь
Регистрация: 02.04.2012
Сообщений: 49
|
это то понятно ))
Кнопка Add: Код:
Код:
Код:
|
06.02.2013, 13:13 | #7 |
Старожил
Регистрация: 09.01.2008
Сообщений: 26,229
|
я бы рекомендовал поставить точки останова и пройтись в пошаговом режиме, на какой строчке вылетит Access Violation - вот с тем объектом и разбираться детальнее - где Вы его убиваете и не создаёте...
|
06.02.2013, 13:33 | #8 | |
Старожил
Регистрация: 16.05.2012
Сообщений: 3,211
|
Цитата:
Начал решать проблему с помощью регулярных выражений. Теперь решаю две проблемы...
|
|
06.02.2013, 13:36 | #9 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
Похоже тут Yurk@ прав. Метод Cancel отменяет все изменения по текущей записи и делает state=dsBrowse. Не проверял, но скорее всего CancelUpdates state не изменяет, остаётся dsInsert и последующая попытка выполнить Insert заканчивается аварийно.
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
06.02.2013, 13:55 | #10 | ||
Пользователь
Регистрация: 02.04.2012
Сообщений: 49
|
Цитата:
Цитата:
|
||
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Вылетает ошибка при вставке в таблицу через Insert (ex. Что здесь не так ) | pavel0088 | SQL, базы данных | 9 | 02.02.2013 07:15 |
Перекрытие вариабл при повторном вызове функции | KOTBASILIO | JavaScript, Ajax | 0 | 18.07.2011 19:09 |
Возникает ошибка исключения при повторном открытии формы | Nik_K | БД в Delphi | 10 | 25.04.2011 23:49 |
ошибка при INSERT INTO; D7, access mdb | helluvaname | Помощь студентам | 4 | 07.01.2010 10:16 |
Ошибка при Выполнении Insert | nimf | БД в Delphi | 2 | 27.11.2007 18:16 |