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

Создание внешних ключей

30.01.2010, 12:13. Показов 13577. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Написал собственный редактор моделей сущность-связь, который должен генерировать sql скрипт(это задание у нас в универе такое). SQL знаю не очень. Вот пример создания таблицы:
T-SQL
1
2
3
4
5
6
7
create table (
    Id int identity primary key,
    Ном_Зач int not null,
    Дисциплина varchar(50) not null,
    Оценка tinyint not null,
    foreign key (Ном_Зач) references Студент (Ном_Зач))
go
У меня следующие вопросы:
1. Таблица Студент обязательно должна быть создана до таблицы Оценка, если да, то как быть со связями 1 к 1 когда одна таблица имеет связь со второй и вторая имеет связь с первой.
2. И второе можно сначала создать все таблицы а потом создать к ним внешние ключи, как нибудь так:
T-SQL
1
create foreign key Оценка(Ном_Зач) references Студент (Ном_Зач)
Заранее благодарен.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.01.2010, 12:13
Ответы с готовыми решениями:

Создание внешних ключей
Привет! написал запрос на создание внешних ключей и выводится такая ошибка В общем, мне необходим этот ключ, тк я их делаю исходя из...

Создание связей двух внешних ключей к к ключевому полю другой таблицы
Задача: Организация службы поддержки, которая по запросу выдает исправную технику взамен неисправной. Имеется пул техники (equipment) и...

Привязка трех внешних ключей
Добрый день. У меня имеется две таблицы Склад (Код ингредиента, Наименование ингредиента, Дата выпуска, Объём, Срок годности,...

4
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
30.01.2010, 13:25
1.1. В Вашем CREATE TABLE не хватает имени таблицы
1.2. Да, таблица Студент обязательно должна быть создана до создания FOREIGN KEY в таблице Оценка
1.3. Если две таблицы относятся друг к другу как 1:1, то непонятно, почему бы все поля не создать в одной таблице, а не в двух.
2. Да, можно сначала создать все таблицы а потом создать к ним внешние ключи, но только так:
T-SQL
1
2
3
4
ALTER TABLE Оценка
ADD CONSTRAINT fkОценкаСтудент
FOREIGN KEY(Ном_Зач)
REFERENCES Студент(Ном_Зач);
0
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
30.01.2010, 13:57
Цитата Сообщение от Semich Посмотреть сообщение
Таблица Студент обязательно должна быть создана до таблицы Оценка, если да, то как быть со связями 1 к 1
а почему связь 1 к 1?
ведь у 1 студента немеряно оценков?
0
Semich
30.01.2010, 14:16

Вот например у нас есть такая модель тогда sql скрипт будет выглядеть для нее следующим образом?
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE Оценка (
предмет text NOT NULL,
бал text NOT NULL,
ном_зачетки INT NOT NULL
);
GO
 
CREATE TABLE Студент (
ФИО text,
ном_зачетки INT NOT NULL UNIQUE
CONSTRAINT PRIMARY KEY (ном_зачетки)
);
GO 
 
/*все что выше уже генерирутся моей программой*/
 
ALTER TABLE Оценка
ADD CONSTRAINT fkОценкаСтудент
FOREIGN KEY(ном_зачетки)
REFERENCES Студент(ном_зачетки;
И после выполнения этого скрипта в базе создадутся две таблицы с внешним ключом по полю ном_зачетки. Надеюсь я все правильно понял.
 Аватар для BasicMan
19318 / 2626 / 84
Регистрация: 17.02.2009
Сообщений: 30,364
30.01.2010, 14:20
Цитата Сообщение от Semich Посмотреть сообщение
Надеюсь я все правильно понял.
да
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.01.2010, 14:20
Помогаю со студенческими работами здесь

Расстановка первичных и внешних ключей
Подскажите, пожалуйста как правильно расставить внешние и первичные ключи таблицы Сделки 1.Наименование торговой сессии ...

Создание внешних ключей в SQL server management studio
Уважаемые Гуру! При работе с MySQL в dbForge studio удобный графический редактор связей между таблицами. Автоматически создаются...

Список внешних ключей
Всем привет! Структура: TABLE domains ( id serial, level integer NOT NULL, name character varying(255), ...

Ошибки внешних ключей
Написал статью Ошибки внешних ключей: errno 150, MySQL error 1005 и другие, в которой перечислил все известные мне случаи возникновения...

Перечисление внешних ключей в строке
Доброго времени суток. Есть таблица Рабочие. На 1 рабочего может быть записано несколько единиц инструмента (id из таблицы Инструмент)....


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru