Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проблема со структурой БД? 
:(
    Опции темы
Zahard
Дата 26.5.2013, 05:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 28.4.2013

Репутация: нет
Всего: нет



Здравствуйте, есть БД с такой схемой:
user posted image
Это БД общежития. 
decree - приказы
relocation - приказы, касающиеся перемещения студентов между комнатами (заселение/выселение и т.д.)
decree_type - тип приказа (Заселение/выселение/переселение и т.д.)
Между decree и relocation связь 1:1, между room и relocation, например, 1:М. 
Сейчас таблица decree выглядит так:
user posted image
Для 5-го студента только 2 приказа типа relocation (1 заселение и 1 переселение)
Когда делаю запрос на список студентов, которых заселили, то вижу такое:
user posted image
У 5-го студента в выборку попадают обе записи, хотя вторая касается перевода, а не заселения. 
Если сделать запрос на переселения, то картина аналогичная:
user posted image
В чем дело может кто объяснить?

PM MAIL   Вверх
password
Дата 27.5.2013, 11:33 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 76
Регистрация: 23.9.2008
Где: Украина, Сумы

Репутация: 4
Всего: 8



Добрый день.
Вы не правильно связываете relocation. Вы связываете по студенту, а нужно по приказу. У вас в relocation 2 записи, вот по студенту и выбирается 2 записи.
Добавьте еще id приказа

...
Join relocation r on r.decree_id=d.decree_id and r.student_id=p.student_id
...

вроде так.

Это сообщение отредактировал(а) password - 27.5.2013, 11:36
PM MAIL Skype   Вверх
Zahard
Дата 27.5.2013, 15:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 28.4.2013

Репутация: нет
Всего: нет



password, Вы оказались правы) Спасибо.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.0588 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.