Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/256: Рейтинг темы: голосов - 256, средняя оценка - 4.56
4 / 4 / 0
Регистрация: 08.09.2009
Сообщений: 90

Как задать внешние ключи в SQL Server Management Studio?

18.01.2010, 07:08. Показов 53133. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как задать внешние ключи в SQL Server Management Studio?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.01.2010, 07:08
Ответы с готовыми решениями:

Как подключится к БД (SQL Server Management Studio)
установил MS SQL server на windows 2008 какую программу установить, чтобы работать с SQL server с рабочего пк, а не с сервера. На...

SQL Server 2012 Management Studio Express не появляется служба SQL Server
Здравствуйте. Установил SQL Server Management Studio Express 2012 , необходимый для работы одной программы конфигурирования устройства. Там...

Настройка SQL Server 2008 для работы с SQL Server Management Studio
Доброго времени суток. Подскажите пожалуйста, что нужно сделать для того, чтобы SQL Server Management Studio соединялось с SQL сервером ?...

14
МИР ВАШЕМУ ДОМУ!!!
57 / 58 / 7
Регистрация: 01.04.2009
Сообщений: 890
Записей в блоге: 1
19.01.2010, 12:58
Что такое внешние ключи
0
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
19.01.2010, 13:05
Внешние ключи
Внешний ключ — это столбец одной таблицы, значения которого совпадают со значениями столбца, являющегося первичным ключом другой таблицы.

Внешние ключи — очень важная часть механизма обеспечения ссылочной целостности данных. Чтобы разобраться в том, что собой представляют внешние ключи, рассмотрим следующий пример.

Таблица Orders содержит единственную строку для каждого заказа, зафиксированного в базе данных. Информация о клиенте хранится в таблице Customers. Заказы в таблице Orders связаны с определенными строками в таблице Customers за счет идентификатора клиента. Идентификатор клиента является первичным ключом в таблице Customers; каждый клиент имеет уникальный идентификатор. Номер заказа является первичным ключом в таблице Orders; каждый заказ имеет свой уникальный номер.

Значения в столбце таблицы Orders, содержащем идентификаторы клиентов, не обязательно уникальные. Если клиент сделал несколько заказов, может быть несколько строк с тем же самым идентификатором клиента (хотя каждая из них будет иметь свой номер заказа). В то же время единственные значения, которые могут появиться в столбце идентификаторов клиента таблицы Orders, — это идентификаторы клиентов из таблицы Customers.

Именно так и образуются внешние ключи. В нашем примере внешний ключ определен как столбец идентификаторов клиента, содержащихся в первичном ключе таблицы Customers, так что этот столбец может принимать только значения, имеющиеся в первичном ключе таблицы Customers.

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

T-SQL
1
2
3
4
5
6
7
CREATE TABLE Orders
(
order_num INTEGER NOT NULL PRIMARY KEY, 
order_date DATETIME NOT NULL, 
cust_id CHAR (10) NOT NULL REFERENCES
Customers (cust_id)
);
Это определение таблицы, использующее ключевое слово REFERENCES для утверждения того факта, что любое значение в столбце cust_id должно быть также и в столбце cust_id таблицы Customers.

Того же результата можно было бы добиться с использованием синтаксиса CONSTRAINT в операторе ALTER TABLE:
T-SQL
1
2
3
ALTER TABLE Customers
ADD CONSTRAINT
FOREIGN KEY (cust_id) REFERENCES Customers (cust_id)

Внешние ключи могут воспрепятствовать случайному удалению данных

В дополнение к тому, что внешние ключи помогают принудительно сохранять целостность ссылочных данных, они могут выполнять много других важных функций. После того как внешний ключ определен, ваша СУБД не позволит удалять строки, связанные со строками в других таблицах. Например, вы не сможете удалить информацию о клиенте, у которого есть заказы. Единственный способ удалить информацию о таком клиенте состоит в предварительном удалении связанных с ним заказов (для чего, в свою очередь, нужно удалить информацию о предметах этих заказов). Поскольку требуется столь методичное и целенаправленное удаление, внешние ключи могут оказать помощь в предотвращении случайного удаления данных.
Однако в некоторых СУБД поддерживается возможность, получившая название каскадноеудаление. Если такая функция реализована, можно удалять все связанные с этой строкой данные при удалении ее из таблицы. Например, если возможно каскадное удаление и имя клиента удаляется из таблицы Customers, все связанные с его заказом строки удаляются автоматически.
0
0 / 0 / 0
Регистрация: 16.12.2009
Сообщений: 31
25.02.2011, 12:49
раскрыть таблицу.
на вкладке "Ключи" нажать правой кнопкой - "Создать внешний ключ...".
0
 Аватар для IvanMIPT
0 / 0 / 0
Регистрация: 21.11.2011
Сообщений: 9
02.04.2012, 10:56
Только вот количество столбцов в обоих таблицах должнро быть одинаковым, а это существенное ограничение.
0
 Аватар для bulavkina
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
25.05.2012, 14:56
Цитата Сообщение от zvezda_t Посмотреть сообщение
раскрыть таблицу.
на вкладке "Ключи" нажать правой кнопкой - "Создать внешний ключ...".
Цитата Сообщение от IvanMIPT Посмотреть сообщение
Только вот количество столбцов в обоих таблицах должнро быть одинаковым, а это существенное ограничение.
Ребят, а если этих столбцов как раз-таки не одинаковое количество, а связи создать надо, то как быть? Менять субд?
(знакома с sql 2 дня )
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
25.05.2012, 15:10
Цитата Сообщение от IvanMIPT Посмотреть сообщение
Только вот количество столбцов в обоих таблицах должнро быть одинаковым, а это существенное ограничение.
О_о
Это где ж такое?
0
 Аватар для bulavkina
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
25.05.2012, 15:11
Цитата Сообщение от pincet Посмотреть сообщение
О_о
Это где ж такое?
в SQL Server Management Studio
я тоже не могу создать связи между 3мя таблицами по этой причине, в каждой разное количество столбцов, программа ругается и не пропускает
0
194 / 193 / 17
Регистрация: 07.11.2010
Сообщений: 477
25.05.2012, 15:15
http://msdn.microsoft.com/ru-r... 89049.aspx
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
25.05.2012, 15:24
Лучший ответ Сообщение было отмечено как решение

Решение

Столбцы, которые выбираются для внешнего ключа, должны иметь одинаковый тип данных с первичными столбцами, которым они соответствуют. Каждый ключ должен содержать одинаковое число столбцов. Например, если первичный ключ на первичной стороне связи состоит из двух столбцов, необходимо сопоставить каждому из этих столбцов столбец таблицы, который будет входить во внешний ключ на другой стороне связи. (c) MSDN

Не путаем количество столбцов в таблицах с количеством столбцов в ключе
3
 Аватар для bulavkina
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
25.05.2012, 16:26
Цитата Сообщение от pincet Посмотреть сообщение
Столбцы, которые выбираются для внешнего ключа, должны иметь одинаковый тип данных с первичными столбцами, которым они соответствуют. Каждый ключ должен содержать одинаковое число столбцов. Например, если первичный ключ на первичной стороне связи состоит из двух столбцов, необходимо сопоставить каждому из этих столбцов столбец таблицы, который будет входить во внешний ключ на другой стороне связи. (c) MSDN

Не путаем количество столбцов в таблицах с количеством столбцов в ключе
Тогда подскажите, пожалуйста, на конкретно моём примере.
Нужно создать sql запрос для создания таблиц и связей схемы базы данных по 3 таблицам.
Я прописала эти 3 таблицы, а при попытке создать внешние ключи выдаёт ошибку со крина. Подскажите, что не так. В голове сумбур)
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE dogovor (
id INT IDENTITY (1,1) PRIMARY KEY NOT NULL,
DATA DATE NOT NULL,
StrahovSumma MONEY NOT NULL,
TarifnayaStavka MONEY NOT NULL,
KodFiliala VARCHAR(1) NOT NULL,
KodStrahovaniya VARCHAR(1) NOT NULL
)
 
CREATE TABLE filials (
KodFiliala VARCHAR(1) PRIMARY KEY NOT NULL,
NaimenovanieFiliala VARCHAR(30) NOT NULL,
Adres VARCHAR(30) NOT NULL,
Telefon VARCHAR(15) NOT NULL
)
 
CREATE TABLE VidStrahovaniya (
KodStrahovaniya VARCHAR(1) PRIMARY KEY NOT NULL,
Naimenovanie VARCHAR(30) NOT NULL
)
Миниатюры
Как задать внешние ключи в SQL Server Management Studio?  
0
194 / 193 / 17
Регистрация: 07.11.2010
Сообщений: 477
25.05.2012, 16:44
T-SQL
1
2
3
ALTER TABLE dogovor
ADD CONSTRAINT
FOREIGN KEY (KodFiliala) REFERENCES filials (KodFiliala)
а так?
0
 Аватар для bulavkina
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
25.05.2012, 16:59
Цитата Сообщение от Leax Посмотреть сообщение
T-SQL
1
2
3
ALTER TABLE dogovor
ADD CONSTRAINT
FOREIGN KEY (KodFiliala) REFERENCES filials (KodFiliala)
а так?
Ругается. Говорит, неверный синтаксис около "KodFiliala"
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
25.05.2012, 17:32
Цитата Сообщение от bulavkina Посмотреть сообщение
2
3
ALTER TABLE dogovor
ADD CONSTRAINT FK_DOG
FOREIGN KEY (KodFiliala) REFERENCES filials (KodFiliala)
имя ограничению дать нужно
1
 Аватар для bulavkina
2 / 2 / 0
Регистрация: 25.05.2012
Сообщений: 20
25.05.2012, 18:32
Цитата Сообщение от pincet Посмотреть сообщение
имя ограничению дать нужно
Работает, спасибо
Потопала тугодумить дальше над запросами
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2012, 18:32
Помогаю со студенческими работами здесь

Microsoft SQL Server Compact Edition в SQL Server Management Studio Express
Не могу понять как настроить SQL Server Management Studio Expres чтоб открывать и создавать бд sql ce. В менеджере просто нет возможности...

Как избежать повторной аутентификации в SQL Server Management Studio?
Всем доброго времени суток. Проблема такая. В SQL Server Management Studio я подсоединяюсь к БД на сервере через Проверку подлинности SQL...

Как сделать выборки в Microsoft Sql Server Management Studio?
Базу данных я создал, а вот выборки не могу понять как надо делать.

Как сделать DropDownList в MS SQL Server Management Studio 2012 Express?
Как сделать DropDownList в MS SQL Server Management Studio 2012 Express, т.е. в одном из полей должно быть фиксированное значение...

Как вывести схему представления таблиц MS SQL Server Management Studio
Начинающий, вышел на первую работу. Есть большая БД, пытаюсь разобраться.MS SQL Server Management Studio 2016. Хотелось бы как то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
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 На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru