Главная страница
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.031 c
3-1166546496
KIR
2006-12-19 19:41
2007.03.18
FastReport 2.54 При печате печатает "кракозябликами"


15-1171961180
Ученик чародея
2007-02-20 11:46
2007.03.18
Как именно пираты вредят развитию IT-области?


3-1166640163
The X
2006-12-20 21:42
2007.03.18
"Table is busy" при попытке добавить новое поле через запрос.


1-1169462971
Kolan
2007-01-22 13:49
2007.03.18
Как полтзоваться ChartTools компонента TChart


2-1171876396
Прохожев Максим
2007-02-19 12:13
2007.03.18
Количество строк в проекте