|
4 / 4 / 0
Регистрация: 08.09.2009
Сообщений: 90
|
|
Как задать внешние ключи в SQL Server Management Studio?18.01.2010, 07:08. Показов 52874. Ответов 14
Метки нет (Все метки)
0
|
|
| 18.01.2010, 07:08 | |
|
Ответы с готовыми решениями:
14
SQL Server 2012 Management Studio Express не появляется служба SQL Server Настройка SQL Server 2008 для работы с SQL Server Management Studio |
|
19318 / 2625 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
|
|||||||||||
| 19.01.2010, 13:05 | |||||||||||
|
Внешние ключи
Внешний ключ — это столбец одной таблицы, значения которого совпадают со значениями столбца, являющегося первичным ключом другой таблицы.
Внешние ключи — очень важная часть механизма обеспечения ссылочной целостности данных. Чтобы разобраться в том, что собой представляют внешние ключи, рассмотрим следующий пример. Таблица Orders содержит единственную строку для каждого заказа, зафиксированного в базе данных. Информация о клиенте хранится в таблице Customers. Заказы в таблице Orders связаны с определенными строками в таблице Customers за счет идентификатора клиента. Идентификатор клиента является первичным ключом в таблице Customers; каждый клиент имеет уникальный идентификатор. Номер заказа является первичным ключом в таблице Orders; каждый заказ имеет свой уникальный номер. Значения в столбце таблицы Orders, содержащем идентификаторы клиентов, не обязательно уникальные. Если клиент сделал несколько заказов, может быть несколько строк с тем же самым идентификатором клиента (хотя каждая из них будет иметь свой номер заказа). В то же время единственные значения, которые могут появиться в столбце идентификаторов клиента таблицы Orders, — это идентификаторы клиентов из таблицы Customers. Именно так и образуются внешние ключи. В нашем примере внешний ключ определен как столбец идентификаторов клиента, содержащихся в первичном ключе таблицы Customers, так что этот столбец может принимать только значения, имеющиеся в первичном ключе таблицы Customers. Вот один из способов определения внешнего ключа:
Того же результата можно было бы добиться с использованием синтаксиса CONSTRAINT в операторе ALTER TABLE:
Внешние ключи могут воспрепятствовать случайному удалению данных В дополнение к тому, что внешние ключи помогают принудительно сохранять целостность ссылочных данных, они могут выполнять много других важных функций. После того как внешний ключ определен, ваша СУБД не позволит удалять строки, связанные со строками в других таблицах. Например, вы не сможете удалить информацию о клиенте, у которого есть заказы. Единственный способ удалить информацию о таком клиенте состоит в предварительном удалении связанных с ним заказов (для чего, в свою очередь, нужно удалить информацию о предметах этих заказов). Поскольку требуется столь методичное и целенаправленное удаление, внешние ключи могут оказать помощь в предотвращении случайного удаления данных. Однако в некоторых СУБД поддерживается возможность, получившая название каскадноеудаление. Если такая функция реализована, можно удалять все связанные с этой строкой данные при удалении ее из таблицы. Например, если возможно каскадное удаление и имя клиента удаляется из таблицы Customers, все связанные с его заказом строки удаляются автоматически.
0
|
|||||||||||
|
0 / 0 / 0
Регистрация: 16.12.2009
Сообщений: 31
|
|
| 25.02.2011, 12:49 | |
|
раскрыть таблицу.
на вкладке "Ключи" нажать правой кнопкой - "Создать внешний ключ...".
0
|
|
|
0 / 0 / 0
Регистрация: 21.11.2011
Сообщений: 9
|
|
| 02.04.2012, 10:56 | |
|
Только вот количество столбцов в обоих таблицах должнро быть одинаковым, а это существенное ограничение.
0
|
|
|
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
|
|||
| 25.05.2012, 14:56 | |||
|
(знакома с sql 2 дня )
0
|
|||
|
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
|
|
| 25.05.2012, 15:10 | |
|
0
|
|
|
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
|
||
| 25.05.2012, 15:11 | ||
|
я тоже не могу создать связи между 3мя таблицами по этой причине, в каждой разное количество столбцов, программа ругается и не пропускает
0
|
||
|
194 / 193 / 17
Регистрация: 07.11.2010
Сообщений: 477
|
|
| 25.05.2012, 15:15 | |
|
0
|
|
|
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
|
|
| 25.05.2012, 15:24 | |
Сообщение было отмечено как решение
Решение
Столбцы, которые выбираются для внешнего ключа, должны иметь одинаковый тип данных с первичными столбцами, которым они соответствуют. Каждый ключ должен содержать одинаковое число столбцов. Например, если первичный ключ на первичной стороне связи состоит из двух столбцов, необходимо сопоставить каждому из этих столбцов столбец таблицы, который будет входить во внешний ключ на другой стороне связи. (c) MSDN
Не путаем количество столбцов в таблицах с количеством столбцов в ключе
3
|
|
|
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
|
|||||||
| 25.05.2012, 16:26 | |||||||
|
Нужно создать sql запрос для создания таблиц и связей схемы базы данных по 3 таблицам. Я прописала эти 3 таблицы, а при попытке создать внешние ключи выдаёт ошибку со крина. Подскажите, что не так. В голове сумбур)
0
|
|||||||
|
194 / 193 / 17
Регистрация: 07.11.2010
Сообщений: 477
|
||||||
| 25.05.2012, 16:44 | ||||||
0
|
||||||
|
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
|
|
| 25.05.2012, 16:59 | |
|
0
|
|
|
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
|
|
| 25.05.2012, 17:32 | |
|
1
|
|
|
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
|
|
| 25.05.2012, 18:32 | |
|
0
|
|
| 25.05.2012, 18:32 | |
|
Помогаю со студенческими работами здесь
15
Microsoft SQL Server Compact Edition в SQL Server Management Studio Express Как избежать повторной аутентификации в SQL Server Management Studio? Как сделать выборки в Microsoft Sql Server Management Studio? Как сделать DropDownList в MS SQL Server Management Studio 2012 Express? Как вывести схему представления таблиц MS SQL Server Management Studio Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|