Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: связи в PostgreSQL 8.3  (Прочитано 10276 раз)
0 Пользователей и 1 Гость смотрят эту тему.
voland
Гость
« : 02-08-2009 09:51 » 

Чет не доходит в чем моя ошибка Не надо . Имеются 2 таблички Сщтрудник и Комната, вот sql-код:
-- Table: "Collaborator"

-- DROP TABLE "Collaborator";

CREATE TABLE "Collaborator"
(
  "Name" text,
  office_phone text,
  inside_phone text,
  home_phone text,
  business text,
  "level" text,
  "Code_col" integer NOT NULL,
  CONSTRAINT "Code_col" PRIMARY KEY ("Code_col"),
  CONSTRAINT "Code_room" FOREIGN KEY ("Code_room")
)
WITH (OIDS=FALSE);
ALTER TABLE "Collaborator" OWNER TO postgres;
////////////////////////////////////////
-- Table: "Room"

-- DROP TABLE "Room";

CREATE TABLE "Room"
(
  "Number" integer,
  "Code_room" integer NOT NULL,
  CONSTRAINT "Code_room" PRIMARY KEY ("Code_room")
)
WITH (OIDS=FALSE);
ALTER TABLE "Room" OWNER TO postgres;
///////////////////
Т.е. таблицы связываются через внешний ключ Code_room, но почему то скрипт ругается на ошибку в 16 строке таблицы Collabarator (Сотрудник).  Меня одолевают смутные сомнения
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 02-08-2009 11:14 » 

voland, а если подумать головой? Как можно ссылаться в FOREIGN KEY на несуществующий объект?
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Kivals
Команда клуба

ca
Offline Offline
Пол: Мужской

WWW
« Ответ #2 : 02-08-2009 12:19 » 

Синтаксис FOREIGN KEY неверный. Или следай его ручками и посмотри какой код сгенерится (pgAdmin III) или внимательно читай хелп.
Записан
voland
Гость
« Ответ #3 : 02-08-2009 12:47 » 

и я понимаю что неверный, а в чем ошибка то? Как реализовать связь таблиц? Ниче не понимаю...
Записан
voland
Гость
« Ответ #4 : 02-08-2009 12:51 » 

Кстати этот sqlчик pgAdmin III и сгенерил, просто я чтобы реализовать связь по совету умеющих добавил строчку CONSTRAINT "Code_room" FOREIGN KEY ("Code_room") из-за которой все проблемы и есть. Просто я никак не могу понять связь то как делается?  Меня одолевают смутные сомнения
Записан
Kivals
Команда клуба

ca
Offline Offline
Пол: Мужской

WWW
« Ответ #5 : 02-08-2009 13:33 » 

Я вижу что это похоже на pgAdmin III, но внешнюю связь ты добавлял сам - и это тоже заметно. Добавь ее в pgAdmin - и ты увидишь что эта инструкция имеет много больше параметров.
Еще на заметку - внешнюю связь нужно добавлять после создания обеих таблиц, иначе как написал RXL ты будешь ссылаться на несуществующий объект, дае если напишешь правильно синтаксис
Записан
voland
Гость
« Ответ #6 : 08-08-2009 16:12 » 

по ходу мне не хватало поля/колонки для связки, а после добавления вроде бы срослось. Да и все делается, конечно, же после создания таблиц и полей. Улыбаюсь
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines