Дата  Запланированые курсы
30.07 Рисование на компьютере при помощи планшета (базовый курс)
30.07 Adobe After Effects. Создание анимации и эффектов
13.08 Средства векторной графики. Adobe Illustrator
27.08 Поисковая оптимизация (SEO)
03.09 Введение в тестирование программного обеспечения
10.09 DEV-J-MP+. Расширенная комплексная программа "Разработчик прикладного программного обеспечения (Язык Java)"
10.09 DEV-J10. Программирование на платформе Java. Введение в язык Java
10.09 MOC-20740B. Установка, Хранение и Вычисления с Windows Server 2016
10.09 Поисковая оптимизация (SEO) для профессионалов
10.09 DEV-J-CP. Комплексная программа "Разработчик прикладного программного обеспечения (Язык Java)"
10.09 Поисковая оптимизация (SEO) для профессионалов
10.09 Компьютерное проектирование в системе AutoCAD (базовый курс)
10.09 MOC-10985. Введение в базы данных SQL
10.09 Основы создания веб-сайтов. Adobe Dreamweaver
10.09 DEV-C22. Стандарт С++11, С++14, С++17 для прикладного программирования
17.09 MOC-20761. Создание запросов данных при помощи Transact-SQL
17.09 DEV-J20. Программирование на платформе Java. Стандартные пакеты
17.09 Средства растровой графики. Adobe Photoshop
24.09 DEV-J30. Программирование на платформе Java. Разработка многоуровневых приложений
24.09 MOC-20741B. Сетевая инфраструктура на основе Windows Server 2016
01.10 MOC-20762. Разработка баз данных SQL
01.10 Компьютерное проектирование в системе AutoCAD (базовый курс)
01.10 Профессиональная верстка сайтов. HTML5 и CSS3
01.10 DEV-С-CP+. Расширенная комплексная программа «Разработчик прикладного программного обеспечения (Языки С и C++)»
01.10 DEV-C10. Процедурное программирование. Языки С/C++
01.10 Основы алгоритмизации и программирования (Группа I)
01.10 Основы алгоритмизации и программирования (Группа II)
02.10 DEV-J-MP+. Расширенная комплексная программа "Разработчик прикладного программного обеспечения (Язык Java)"
02.10 DEV-J10. Программирование на платформе Java. Введение в язык Java
08.10 MOC-20764. Администрирование инфраструктуры баз данных SQL
08.10 MOC-20742B. Инфраструктура идентификации на основе Windows Server 2016
08.10 DEV-J60. Технологии разработки корпоративных приложений на платформе Java Enterprise Edition (Java EE)
08.10 Введение в тестирование программного обеспечения
08.10 QA-QAAB. Автоматизация тестирования ПО (Базовый курс)
15.10 Компьютерное проектирование в системе AutoCAD (профессиональный курс)
15.10 Средства векторной графики. Adobe Illustrator
15.10 DEV-OCPJP. Подготовка к сдаче сертификационных экзаменов серии Oracle Certified Professional Java Programmer
22.10 MOC-20744A. Безопасность инфраструктуры средствами Windows Server 2016
22.10 Введение в тестирование программного обеспечения
22.10 MOC-10987. Настройка производительности и оптимизация баз данных SQL
22.10 Основы создания веб-сайтов. Adobe Dreamweaver
24.10 NET-DLINKSW-LAB. Технологии коммутации современных сетей Ethernet. Лабораторный практикум
25.10 DEV-J20. Программирование на платформе Java. Стандартные пакеты
29.10 MOC-10961B. Автоматизация администрирования с Windows PowerShell
07.11 DEV-C20. Объектно-ориентированное программирование. Базовый уровень. Язык С++
12.11 Профессиональная верстка сайтов. HTML5 и CSS3
12.11 Компьютерное проектирование в системе AutoCAD (базовый курс)
19.11 DEV-J30. Программирование на платформе Java. Разработка многоуровневых приложений
26.11 Средства растровой графики. Adobe Photoshop
26.11 Поисковая оптимизация (SEO)
03.12 Компьютерное проектирование в системе AutoCAD (базовый курс)
03.12 DEV-C21. Объектно-ориентированное программирование. Углубленное изучение. Язык С++
10.12 Основы создания веб-сайтов. Adobe Dreamweaver
10.12 Поисковая оптимизация (SEO) для профессионалов
10.12 Средства векторной графики. Adobe Illustrator
17.12 Компьютерное проектирование в системе AutoCAD (профессиональный курс)
09.01 DEV-C22. Стандарт С++11, С++14, С++17 для прикладного программирования
14.01 DEV-OCPJP. Подготовка к сдаче сертификационных экзаменов серии Oracle Certified Professional Java Programmer
04.02 DEV-QT10. Прикладное программирование на С++ с использованием Qt. Базовый уровень
11.02 DEV-J60. Технологии разработки корпоративных приложений на платформе Java Enterprise Edition (Java EE)
11.03 Введение в тестирование программного обеспечения
11.03 Введение в тестирование программного обеспечения
Открыт набор на осенний семестр в Академию информатики для школьников Открыт набор на осенний семестр на программы второго высшего образования
Добро пожаловать, Гость! Чтобы использовать все возможности Вход или Регистрация.

Уведомление

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.o..._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 (3)
Быстрый переход  
Вы не можете создавать новые темы в этом форуме.
Вы не можете отвечать в этом форуме.
Вы не можете удалять Ваши сообщения в этом форуме.
Вы не можете редактировать Ваши сообщения в этом форуме.
Вы не можете создавать опросы в этом форуме.
Вы не можете голосовать в этом форуме.