Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> reference и foreign key, отличия 
:(
    Опции темы
марина
Дата 19.11.2007, 13:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 2.8.2006

Репутация: нет
Всего: нет



Подскажите чем отличаются reference и foreign key?
те когда мы обьявляем какой-то столбец, как foreign key, и когда обьявляем тот же столбец, как reference
PM MAIL   Вверх
Akella
Дата 20.11.2007, 10:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 3
Всего: 329



Цитата(марина @  19.11.2007,  13:45 Найти цитируемый пост)
reference и foreign key

reference - это ссылочная целостность
foreign key - это внешний ключ

Между объектами имеется связь, которая приводит их к взаимной зависимости, и поддержка этих зависимостей поддерживается сервером, а не клиентом. А вот связь уже обеспечивается этим самым внешним ключом, индексом.

Это сообщение отредактировал(а) Akella - 20.11.2007, 10:44
PM MAIL   Вверх
марина
Дата 20.11.2007, 16:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 97
Регистрация: 2.8.2006

Репутация: нет
Всего: нет



те если я  правильно понимаю, то столбец помеченный как внешний клююч ничем не отличается от столбца помеченного как reference, так?
просто reference более краткая форма записи, так?

PM MAIL   Вверх
Akella
Дата 21.11.2007, 10:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 3
Всего: 329



где, чем помеченный?
PM MAIL   Вверх
Akella
Дата 21.11.2007, 10:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 3
Всего: 329



Цитата(марина @  20.11.2007,  16:50 Найти цитируемый пост)
просто reference более краткая форма записи, так?

та не, просто reference - это не форма записи, а это вид связывания двух таблиц по средствам этого самого foreign key`я
PM MAIL   Вверх
Deniz
Дата 22.11.2007, 07:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 7
Всего: 44



Смотрим как это все записывается, например так:
Код
ALTER TABLE TableName ADD CONSTRAINT FKName FOREIGN KEY (FieldName) REFERENCES refTableName (refFieldName)
ON UPDATE CASCADE ON DELETE SET NULL;

Итак попробую объяснить,
внешний ключ - это поле в таблице
REFERENCES - это правило по которому СУБД обрабатывает таблицу с внешним ключом.
В правиле присутствует:
  • имя поля в таблице(внешний ключ)
  • ссылка на внешнюю таблицу
  • ссылка на поле во внешней таблице
  • действия по изменениям во внешней таблице (ON UPDATE/ON DELETE)
  • действия по изменению/добавлению значения во внешний ключ(попытка записать в FK значение, которое отсутствует во внешней таблице, приведет к ошибке).


Это сообщение отредактировал(а) Deniz - 22.11.2007, 07:37


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0952 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.