Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Вопрос по SQL

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
MaximusX



Зарегистрирован: 10.02.2004
Сообщения: 12

СообщениеДобавлено: Вт Фев 10 2004 06:01    Заголовок сообщения: Вопрос по SQL Ответить с цитатой

Имеется следующий запрос:

SELECT
C.PrimaryKeyC,
max(A.SomeField)
FROM
A, B, C
WHERE
A.PrimaryKeyB = B.PrimaryKeyB AND
B.PrimaryKeyC = C.PrimaryKeyC
GROUP BY
C.PrimaryKeyC

Необходимо, помимо максимального значения поля SomeField из таблицы A вернуть еще и значение ее первичного ключа, относящегося к этой записи, т.е. A.PrimaryKey. Все услажняестя тем, что поле C.PrimaryKey выбирать нужно обязательно.
Пожалуйста, подскажите как это можно сделать.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
igis
Гость





СообщениеДобавлено: Чт Фев 19 2004 10:18    Заголовок сообщения: ответ на вопрос по SQL Ответить с цитатой

Одно из возможных решений следующее (если я правильно понял проблему):

SELECT C_1.PrimaryKeyC, A_1.PrimaryKeyA, A_1.SomeField
FROM C C_1, B B_1, A A_1
WHERE (A_1.PrimaryKeyB = B_1.PrimaryKeyB) AND
(B_1.PrimaryKeyC = C_1.PrimaryKeyC) AND
(A_1.SomeField IN (SELECT MAX(A.SomeField)
FROM C, B, A
WHERE (A.PrimaryKeyB = B.PrimaryKeyB) AND
(B.PrimaryKeyC = C.PrimaryKeyC) AND
(C.PrimaryKeyC = C_1.PrimaryKeyC)
GROUP BY C.PrimaryKeyC
)
)
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...