powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Delphi [игнор отключен] [закрыт для гостей] / warning в fib+
20 сообщений из 20, страница 1 из 1
warning в fib+
    #39559248
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добрый день
Подскажите как перехватить warning/error при выполнении запроса (попытка вставить дублирующую запись в таблицу с ПК как пример )?
...
Рейтинг: 0 / 0
warning в fib+
    #39559252
Любезный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
RTFM TpFIBErrorHandler.
...
Рейтинг: 0 / 0
warning в fib+
    #39559253
Любезный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
автор(попытка вставить дублирующую запись в таблицу с ПК как пример )?
Это не warning, а полноценное исключение.
...
Рейтинг: 0 / 0
warning в fib+
    #39559256
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gallemar,
никак.
Ворнинги в компайлтайме живут, онли.
Или объясняй, что ты имеешь в виду.
...
Рейтинг: 0 / 0
warning в fib+
    #39559261
YuRock
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
чччДВорнинги в компайлтайме живут, онли
Ну, так если запрос создает ХП, например, или блок запускает, варнинги могут быть. Например, IBExpert пишет варнинги типа "variable declared but never used". Не уверен, правда, что это сервер присылает, а не IBExpert такой умный, но вряд ли.
...
Рейтинг: 0 / 0
warning в fib+
    #39559264
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
YuRockчччДВорнинги в компайлтайме живут, онли
Ну, так если запрос создает ХП, например, или блок запускает, варнинги могут быть. Например, IBExpert пишет варнинги типа "variable declared but never used". Не уверен, правда, что это сервер присылает, а не IBExpert такой умный, но вряд ли.
Ну ты совсем ку-ку, что ли. Или толлишь постоянно.

Ибэксперт сам такой умный, серверу пофиг.
...
Рейтинг: 0 / 0
warning в fib+
    #39559325
Фотография Док
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gallemar,

Любезный правильно подсказал. Отлавливай GDS код. В демках или на сайте у фибов примеры были
...
Рейтинг: 0 / 0
warning в fib+
    #39559635
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ДокGallemar,

Любезный правильно подсказал. Отлавливай GDS код. В демках или на сайте у фибов примеры были

Мне надо поймать ошибку при вставке дублирующей записи в таблицу с ПК
Invalid insert or update value(s): object columns are constrained - no 2 table rows can have duplicate column values.
violation of PRIMARY or UNIQUE KEY constraint "PK_LOCK_DOC" on table "LOCK_DOC".
Problematic key value is ("DOCHEAD" = 42351648).

И если она есть - сделать запись в логе и продолжить выполнение с другого блока.
...
Рейтинг: 0 / 0
warning в fib+
    #39559640
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЛюбезныйRTFM TpFIBErrorHandler.
С ним проблема:
Undeclared identifier: 'EFIBError'

в


procedure pFibErrorHandler1FIBErrorEvent(Sender: TObject;
ErrorValue: EFIBError; KindIBError: TKindIBError;
var DoRaise: Boolean);

Это что, какой-то косяк с фибами?
...
Рейтинг: 0 / 0
warning в fib+
    #39559647
Любезный
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Надо смотреть, в каком модуле прописан класс EFIBError, и прописать этот модуль в uses.
Открой пакет с фибами и поищи поиском.
...
Рейтинг: 0 / 0
warning в fib+
    #39559680
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Любезный,

искать в FIBPlus7.dpk, я же прввильно понял?
...
Рейтинг: 0 / 0
warning в fib+
    #39559709
mvb
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЛюбезныйEFIBError
он в FIB.pas
...
Рейтинг: 0 / 0
warning в fib+
    #39559751
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЛюбезныйНадо смотреть, в каком модуле прописан класс EFIBError, и прописать этот модуль в uses.
Открой пакет с фибами и поищи поиском.

EFIBError = class(EDatabaseError)

Класс EDatabaseError прописать?
...
Рейтинг: 0 / 0
warning в fib+
    #39559753
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
стоп, гоню. Разобрался
...
Рейтинг: 0 / 0
warning в fib+
    #39559754
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Хм, а как с помощью ErrorHandler подавить эксепшен, сделать запись в лог и просто продолжить выполнение кода. Крутил ErrorHandler, всё равно окно с ошибкой получаю
...
Рейтинг: 0 / 0
warning в fib+
    #39559756
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
GallemarХм, а как с помощью ErrorHandler подавить эксепшен, сделать запись в лог и просто продолжить выполнение кода. Крутил ErrorHandler, всё равно окно с ошибкой получаю
Записать в лог? С помощью ErrorHandler?
...
Рейтинг: 0 / 0
warning в fib+
    #39559757
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gallemar,

Из документации Централизованная обработка ошибок – TpFIBErrorHandler

FIBPlus позволяет централизованно обрабатывать ошибки и исключительные, которые возникают при работе «своих» компонентов. Для этого существует компонент TpFIBErrorHandler с единственным событием OnFIBErrorEvent :
Код: pascal
1.
2.
TOnFIBErrorEvent = procedure(Sender: TObject; ErrorValue: EFIBError;
 KindIBError: TKindIBError; var DoRaise: boolean) of object;

где

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
TKindIBError = (keNoError, keException, keForeignKey, keLostConnect,
 keSecurity, keCheck, keUniqueViolation, keOther);
EFIBError = class(EDatabaseError)
 //..
 property SQLCode : Long read FSQLCode ;
 property IBErrorCode: Long read FIBErrorCode ;
 property SQLMessage : string read FSQLMessage;
 property IBMessage : string read FIBMessage;
end;


Опция DoRaise управляет дальнейшим поведением библиотеки после выполнения обработчика, то есть, указывает, будет ли генерироваться стандартное исключение или нет.
Опция может быть использована для стандартной обработки различных типов ошибок перечисленных в KindIBError
...
Рейтинг: 0 / 0
warning в fib+
    #39559759
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
чччДGallemarХм, а как с помощью ErrorHandler подавить эксепшен, сделать запись в лог и просто продолжить выполнение кода. Крутил ErrorHandler, всё равно окно с ошибкой получаю
Записать в лог? С помощью ErrorHandler?
Нет, просто запись сделать и подавить эксепшен. Типа ничего не было, дальше пьем
...
Рейтинг: 0 / 0
warning в fib+
    #39559760
чччД
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gallemar,

DoRaise же.
...
Рейтинг: 0 / 0
warning в fib+
    #39559778
Фотография Gallemar
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
чччД, спасибо
...
Рейтинг: 0 / 0
20 сообщений из 20, страница 1 из 1
Форумы / Delphi [игнор отключен] [закрыт для гостей] / warning в fib+
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]