Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
3 / 3 / 0
Регистрация: 09.11.2013
Сообщений: 41

SQL - не могу вытянуть ключевое поле из нескольких сложных подзапросов

25.03.2016, 18:27. Показов 1256. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые знатоки,

Таблицы на самом деле более сложные, но не могу уяснить принцип, и для примера упрощаю ситуацию.

Подскажите, пожалуйста, почему простейший запрос:

SQL
1
2
3
4
SELECT A.[INDEX] AS [INDEX], *
 FROM (tb1 AS A  LEFT JOIN tb2 AS B  ON A.[INDEX] = B.[INDEX])
 LEFT JOIN tb3 AS C
 ON A.[INDEX] = C.[INDEX]
в поле [Index] выдает пустую выборку, а если написать так:
SQL
1
2
3
4
SELECT A.[INDEX] AS [INDEX]
 FROM (tb1 AS A  LEFT JOIN tb2 AS B  ON A.[INDEX] = B.[INDEX])
 LEFT JOIN tb3 AS C
 ON A.[INDEX] = C.[INDEX]
то все нормально, индексы выводятся правильно, но, понятное дело, одним столбцом. Проверяю в построителе запросов Access.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.03.2016, 18:27
Ответы с готовыми решениями:

Ключевое поле для нескольких таблиц
Доброго всем времени суток! Разрабатываю приложение с базой данных в C++builder и столкнулся со следующей проблемой: Есть 3 таблицы,...

Ключевое поле
Здравствуйте! При проектировании базы данных возник вопрос: должно ли каждое отношение базы данных содержать ключевое поле (первичный...

ключевое поле
Не знаю сложный это вопрос или нет, я с SQL SERVER раньше не работал. Задача следующая: Есть ключевое поле, связанное с другим полем в...

5
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,936
Записей в блоге: 4
25.03.2016, 18:34
но я не нашла в них разницы, похоже они равны
просмотрела звездочку
Visual Basic
1
2
3
4
5
6
7
8
9
10
SELECT A.[INDEX] AS [INDEX], *
 FROM (tb1 AS A  LEFT JOIN tb2 AS B  ON A.[INDEX] = B.[INDEX])
 LEFT JOIN tb3 AS C
 ON A.[INDEX] = C.[INDEX]
 
 
SELECT A.[INDEX] AS [INDEX]
 FROM (tb1 AS A  LEFT JOIN tb2 AS B  ON A.[INDEX] = B.[INDEX])
 LEFT JOIN tb3 AS C
 ON A.[INDEX] = C.[INDEX]
0
3 / 3 / 0
Регистрация: 09.11.2013
Сообщений: 41
25.03.2016, 18:56  [ТС]
В звездочке все и дело.
0
Эксперт MS Access
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
25.03.2016, 19:02
Попробуйте такой запрос, связывая таблицы попарно c tb1
SQL
1
2
3
4
5
6
SELECT A.[INDEX] AS [INDEX], *
FROM tb1 AS A, 
(SELECT A.INDEX AS indAB, B.* FROM tb1 AS A LEFT JOIN tb2 B ON A.[INDEX] = B.[INDEX]) t1,
(SELECT A.INDEX AS indAC, C.* FROM tb1 AS A LEFT JOIN tb3 C ON A.[INDEX] = C.[INDEX]) t2,
A LEFT JOIN t1 ON A.[INDEX] = t1.indAB,
A LEFT JOIN t2 ON A.[INDEX] = t2.indAC
1
шапоклякистка 8-го дня
 Аватар для texnik-san
3681 / 2241 / 391
Регистрация: 26.06.2015
Сообщений: 4,647
Записей в блоге: 1
25.03.2016, 20:55
Лучший ответ Сообщение было отмечено Freshman1976 как решение

Решение

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

Коллизия циклической ссылки на само себя, возникающая из-за того, что поле дважды в списке вычисляемых полей упоминается.
1
3 / 3 / 0
Регистрация: 09.11.2013
Сообщений: 41
26.03.2016, 14:56  [ТС]
И ведь действительно так )
Переименовал псевдоним и заработало. Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.03.2016, 14:56
Помогаю со студенческими работами здесь

Ключевое поле
На кнопке есть следующий код, поле ЖЕТОН является ключевым и значения на нем не могут повторяться. На форме есть "менюшка",...

Ключевое поле
В форму в три поля вводится ФИО заявителя. Ключевое поле состоит из 1-х трех букв ФИО заявителя. Например, Иванов Сергей Петрович,...

Ключевое поле: ГОД
Всем доброе время суток, как вам такая задачка: Возможно ли сделать таблицу, с ключевым полем год??? Например там будут года с 2000 по...

Как сделать ключевое поле?
Вот у меня есть столбик в таблице, код студента, и там счетчик, т.е каждый следующий студент принимает начение на 1 больше предидущего, но...

Правильное ключевое поле таблицы
Добрый день! Вот, везде пишут, что надо "Код" делать ключевым полем таблицы. А мне кажется, что можно использовать что-либо значащее...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru