Дата  Запланированые курсы
24.11 Linux-MP. Модульная программа «Архитектура и администрирование Linux»
24.11 Linux-LE. Основы архитектуры и администрирования Linux
26.11 Поисковая оптимизация (SEO)
26.11 Средства растровой графики. Adobe Photoshop
26.11 Управление проектами (MS Project)
27.11 DEV-J30. Программирование на платформе Java. Разработка многоуровневых приложений (Группа II)
27.11 DEV-J30. Программирование на платформе Java. Разработка многоуровневых приложений (Группа I)
28.11 CORTEX-M-MP. Введение в технологии разработки систем управления на базе МК с RISC ядром ARM Cortex-M
28.11 CORTEX-M-INTRO. Введение в современную микроконтроллерную технику
03.12 Трёхмерное моделирование. 3ds Max
03.12 Компьютерное проектирование в системе AutoCAD (базовый курс)
03.12 DEV-C21. Объектно-ориентированное программирование. Углубленное изучение. Язык С++
07.12 DEV-PY200. Объектно-ориентированное программирование на языке Python
10.12 Основы создания веб-сайтов. Adobe Dreamweaver
10.12 Поисковая оптимизация (SEO) для профессионалов
10.12 Средства векторной графики. Adobe Illustrator
12.12 Инструменты бизнес-анализа Microsoft Excel: PowerPivot, PowerView
12.12 CORTEX-M-RISC. RISC-архитектура ARM Cortex-M в микроконтроллерах
17.12 MOC-20762. Разработка баз данных SQL
17.12 Работа в MS Excel. Расширенные возможности
17.12 Компьютерное проектирование в системе AutoCAD (профессиональный курс)
17.12 Adobe After Effects. Создание анимации и эффектов
09.01 DEV-C22. Стандарт С++11, С++14, С++17 для прикладного программирования
14.01 DEV-OCPJP. Подготовка к сдаче сертификационных экзаменов серии Oracle Certified Professional Java Programmer
14.01 DEV-OCPJP. Подготовка к сдаче сертификационных экзаменов серии Oracle Certified Professional Java Programmer
16.01 CORTEX-M-STM32F. Семейство МК компании ST Microelectronics STM32Fxxx с вычислительным ядром ARM Cortex M3
19.01 Linux-LF. Расширенное администрирование ОС Linux
04.02 DEV-QT10. Прикладное программирование на С++ с использованием Qt. Базовый уровень
11.02 DEV-J60. Технологии разработки корпоративных приложений на платформе Java Enterprise Edition (Java EE)
11.02 DEV-J60. Технологии разработки корпоративных приложений на платформе Java Enterprise Edition (Java EE)
13.02 CORTEX-M-RTOS. Разработка управляющих программ для МК систем управления с использованием многозадачных ОС реального времени
11.03 Введение в тестирование программного обеспечения
11.03 Введение в тестирование программного обеспечения
11.03 Введение в тестирование программного обеспечения
20.03 NET-DLINKSW-LAB. Технологии коммутации современных сетей Ethernet. Лабораторный практикум
Открыт набор на осенний семестр в Академию информатики для школьников Открыт набор на осенний семестр на программы второго высшего образования
Добро пожаловать, Гость! Чтобы использовать все возможности Вход или Регистрация.

Уведомление

Icon
Error

Странности натурального объединения таблиц.
ALEART
#1 Оставлено : 23 августа 2010 г. 2:14:42(UTC)
Ранг: Участник

Группы: Зарегистрированные пользователи
Зарегистрирован: 20.09.2009(UTC)
Сообщений: 15
Баллов: 45
Откуда: Russia Санкт-Петербург

Уважаемые участники форума! Прошу Ваших советов и помощи в решении одной странной проблемы.

Итак, дано: одна из задач из книги Oracle Database 10G - SQL Fundamentals, которая требует получить полные адреса для всех департаментов (департамент - адрес - город - округ - страна). Составляю следующий запрос:
Код:

SELECT
department_id,
department_name,
location_id,
street_address,
city,
country_name
FROM departments
NATURAL JOIN locations
NATURAL JOIN countries
ORDER BY department_id;

и получаю следующую картину: таблица locations объединяется с departments как и положено - один в один, но при объединении результата с таблицей countries каждая пара "департамент - расположение" объединяется с КАЖДОЙ из стран в таблице countries. Хотя согласно теории и информации из умных книжек, подцепляться должна только одна страна.

При всём при этом: если в список полей в блоке SELECT добавить country_id или поменять порядок объединения, скажем, на следующий:
Код:

FROM locations
NATURAL JOIN countries
NATURAL JOIN departments

- то таблица countries сразу объединяется как положено: одна страна на один департаменто-адрес.

Соответственно хотелось бы узнать - чем может объясняться столь странное поведение (использую версию 10g XE для Linux)?


Заранее спасибо.

Людь в чёрном
Людь в чёрном
Реклама
Margarita.Lukina
#2 Оставлено : 23 августа 2010 г. 16:03:36(UTC)
Ранг: Активный Участник

Группы: Зарегистрированные пользователи
Зарегистрирован: 10.02.2006(UTC)
Сообщений: 156
Баллов: 468
Откуда: Russia Spb

Добрый день. Это не очень стабильный способ (оператор), который не рекомендуется использовать при объединение более 2х таблиц. Oracle поддерживает inner join ... on инструкцию, с явным перечислением колонок, по которым идет объединение. Воспользуйтесь ей. И все должно получиться.
Margarita Lukina
ALEART
#3 Оставлено : 24 августа 2010 г. 0:43:02(UTC)
Ранг: Участник

Группы: Зарегистрированные пользователи
Зарегистрирован: 20.09.2009(UTC)
Сообщений: 15
Баллов: 45
Откуда: Russia Санкт-Петербург

Спасибо, будем знать. Просто в книжке эту задачу предлагалось решить именно через NATURAL JOIN и я до последнего момента надеялся что это я где-то что-то пропустил.
Людь в чёрном
truel
#4 Оставлено : 29 августа 2010 г. 23:26:51(UTC)
Ранг: Активный Участник

Группы: Зарегистрированные пользователи
Зарегистрирован: 21.06.2007(UTC)
Сообщений: 68
Баллов: 204
Откуда: Russia StPetersburg

Natural join еще дает сбой при www.orafaq.com/wiki/Natural_join:
Natural joins may cause problems if columns are added or renamed. Also, no more than two tables can be joined using this method. So, it is best to avoid natural joins as far as possible
RSS Лента  Atom Лента
Пользователи, просматривающие эту тему
Guest
Быстрый переход  
Вы не можете создавать новые темы в этом форуме.
Вы не можете отвечать в этом форуме.
Вы не можете удалять Ваши сообщения в этом форуме.
Вы не можете редактировать Ваши сообщения в этом форуме.
Вы не можете создавать опросы в этом форуме.
Вы не можете голосовать в этом форуме.