|
4 / 4 / 0
Регистрация: 08.09.2009
Сообщений: 90
|
|
Как задать внешние ключи в SQL Server Management Studio?18.01.2010, 07:08. Показов 53133. Ответов 14
Метки нет (Все метки)
0
|
|
| 18.01.2010, 07:08 | |
|
Ответы с готовыми решениями:
14
SQL Server 2012 Management Studio Express не появляется служба SQL Server Настройка SQL Server 2008 для работы с SQL Server Management Studio |
|
19318 / 2626 / 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
|
|||
|
1655 / 1154 / 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
|
|
|
1655 / 1154 / 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
|
|
|
1655 / 1154 / 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 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|