Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.02.11;
Скачать: CL | DM;

Вниз

Создание внешнего ключа - глюк ?   Найти похожие ветки 

 
PEAKTOP ©   (2006-11-18 13:38) [0]

Доброе время суток
Есть таблицы

CREATE TABLE TABL$MASTER(
 ID INTEGER NOT NULL,
 .....
);

ALTER TABLE TABL$MASTER
 ADD CONSTRAINT C_PK$MASTER_ID PRIMARY KEY (ID) USING INDEX INDX$MASTER_ID;

CREATE TABLE TABL$DETAIL(
 MASTER_ID INTEGER NOT NULL,
 ........
);

При попытке создать внешний ключ

ALTER TABLE TABL$DETAIL
 ADD CONSTRAINT C_FK$DETAIL_MASTER_ID FOREIGN KEY (MASTER_ID) REFERENCES TABL$MASTER (ID) ON DELETE CASCADE ON UPDATE CASCADE USING INDEX INDX$DETAIL_MASTER_ID;

Выдает ошибку

Невозможно подтвердить транзакцию:
violation of FOREIGN KEY constraint "".
violation of FOREIGN KEY constraint "C_PK$MASTER_ID" on table "TABL$MASTER".
Foreign key reference target does not exist.

Ошибка даже не в выполнении скрипта на COMMIT транзакции. В структуре базы на таблицу TABL$MASTER ссылается уже с десяток таблиц. Попробовал монопольно к базе подключиться - тоже самое.
В чем дело может быть ?


 
unknown ©   (2006-11-18 17:40) [1]

Хм.
После изменения метаданных следует реконнект делать.
А точно reference target exist ?
Если проблема не в этом - тогда gfix-ом ошибки искать.


 
PEAKTOP ©   (2006-11-18 18:42) [2]

> После изменения метаданных следует реконнект делать.

В том и вопрос, что не могу я это изменение метаданных сделать.

 ......
 IBSQL.ExecSQL; // пока все нормально
 IBSQL.Transaction.Commit; // Вот здесь и ловим исключение.
 .....
 
В IBExpert-e тоже самое.


 
PEAKTOP ©   (2006-11-18 18:49) [3]

Нашел. В таблице TABL$DETAIL была кривая запись. Выполнение скрипта

DELETE FROM TABL$DETAIL DD
WHERE NOT(EXISTS(SELECT MM.ID FROM TABL$MASTER MM WHERE (MM.ID = DD.MASTER_ID)))

все вылечило.

Пост считаю закрытым.


 
Desdechado ©   (2006-11-18 20:17) [4]

violation of FOREIGN KEY constraint
это переводится как наружение ссылочной целостности, т.е. очевидно, что есть записи, не удовлетворяющие этому условию



Страницы: 1 вся ветка

Текущий архив: 2007.02.11;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.071 c
4-1159284221
Dmitry_177
2006-09-26 19:23
2007.02.11
Посылать сообщения сервису


2-1169663332
Lamer666
2007-01-24 21:28
2007.02.11
Как запустить программу КАК процесс??


15-1169045417
Hillbert
2007-01-17 17:50
2007.02.11
Оценка работы


15-1169201986
altex
2007-01-19 13:19
2007.02.11
Защита Приложения.


8-1150563709
Denister
2006-06-17 21:01
2007.02.11
конвертировать RTF в простой текст (без VCL)