С Новым годом! Форум программистов, компьютерный форум, киберфорум
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. Показов 52874. Ответов 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 / 2625 / 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
1654 / 1153 / 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
1654 / 1153 / 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
1654 / 1153 / 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru