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

Вниз

FireBird   Найти похожие ветки 

 
DrDe   (2007-02-19 14:07) [0]

Как создавать связи в таблицах FireBird.?


 
unknown ©   (2007-02-19 14:11) [1]

alter table xxx add constraint и т.д.
Это называется DDL и для работы с FB надо знать как DDL, так и DML.
SQL вобщем.


 
Sergey13 ©   (2007-02-19 14:13) [2]

Скачай ИБЭксперт - там все по русски и мышкой. http://www.ibexpert.com/
Есть еще вариант выучить DDL подмножество языка SQL.


 
DrDe   (2007-02-19 14:18) [3]


> unknown ©   (19.02.07 14:11) [1]


> Sergey13 ©   (19.02.07 14:13) [2]

Да блин разобраться не могу SQL 2000 пересел думал за один день разбирусь....
Не тут то было... :o)


 
Sergey13 ©   (2007-02-19 14:35) [4]

> [3] DrDe   (19.02.07 14:18)

Ну так скачай тулзу то. Бесплатно.


 
Val ©   (2007-02-19 15:21) [5]

"А в Конотопе что, небо твердое?"(с)
"связи в таблицах" мсскл иначе создаются?


 
Romkin ©   (2007-02-19 15:28) [6]

Val ©   (19.02.07 15:21) [5] Они там с извращениями делаются вроде :)


 
Romkin ©   (2007-02-19 15:31) [7]

Да и фиг ты за день разберешься в версионнике, пересев с блокировочника :))


 
Desdechado ©   (2007-02-19 15:35) [8]

> Да и фиг ты за день разберешься в версионнике, пересев с  блокировочника
B каким боком это к FK относится?


 
Romkin ©   (2007-02-19 15:39) [9]

Desdechado ©   (19.02.07 15:35) [8] Это я телепаю. Щаз временные таблицы искать будет... Блокировки учитывать, которых нет...


 
Reindeer Moss Eater ©   (2007-02-19 15:40) [10]

Связи таблиц - вещь чисто умозрительная. Их не создают. Их имеют ввиду.


 
kaif ©   (2007-02-19 16:38) [11]

Reindeer Moss Eater ©   (19.02.07 15:40) [10]
Связи таблиц - вещь чисто умозрительная. Их не создают. Их имеют ввиду.


Это, ИМХО, верный ответ.

Что касается Foreign Key, то эту тему принято называть "декларативной ссылочной целостностью". И вопрос тогда должен звучать так "как защитить ссылочную целостность данных на уровне связей между таблицами?".

В IB внешние ключи создаются при помощи команд вида:

ALTER TABLE
 <имя таблицы>
ADD COSTRAINT
 <имя констрейнта (удобно потом удалять констрейнт, имеющий имя)> FOREIGN KEY
 (<список имен колонок через запятую>)
REFERENCES <таблица, имеющая уникальный ключ> (<список имен колонок через запятую, которые соответствуют уникальному ключу>)

Например:

ALTER TABLE sales ADD CONSTRAINT fk_sales_customer FOREIGN KEY (customer_id) REFERENCES customer(id)

После такого объявления в таблицу sales невозможно будет добавить запись, если customer_id в этой записи отсутствует в поле id таблицы customer. И обратное также верно. Невозможно будет удалить из таблицы customer запись, значение id которой используется в таблице sales и невозможно будет изменить значение id в таблице customer, если это значение используется в поле customer_id таблицы sales.

Объявление можно дополнить фразами ON DELETE CASCADE. Тогда удаление записи из таблицы customer станет возможным. Просто оно повлечет предварительное удаление ВСЕХ записей из sales, которые ссылаются на это значение id. Иногда я использую это дополнение к декларации внешнего ключа.

Объявление можно дополнить и фразой ON UPDATE CASCADE. Тогда изменение id, который используется, повлечет изменение customer_id у всех записей в sales. Я лично это дополнение никогда не использую, так как пользуюсь суррогатными ключами для организации связей между таблицами.


 
Desdechado ©   (2007-02-19 16:41) [12]

kaif ©   (19.02.07 16:38) [11]
Прямо лекция какая-то ;)



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

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

Наверх




Память: 0.49 MB
Время: 0.154 c
2-1172578775
Ivolg
2007-02-27 15:19
2007.03.18
Обратная функция


15-1172361724
Суслик
2007-02-25 03:02
2007.03.18
http://delphigfx.mastak.ru/


15-1171879112
Ega23
2007-02-19 12:58
2007.03.18
В Delphi7 - Project Manager


2-1172485149
Oleg_teacher
2007-02-26 13:19
2007.03.18
Прокрутка Stringgrid


15-1171289071
Rentgen
2007-02-12 17:04
2007.03.18
Квантовый компьютер продемонстрируют на следующей неделе