Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.12.2011, 10:11
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию Максимальное значение

Здравствуйте, подскажите как сделать?

У меня есть 2 таблицы, 1-сотрудники, 2-аттестация.
Связь один ко многим, то есть для каждой записи из первой таблицы имеется несколько записей из второй таблицы.! Вопрос, как сформировать sql-запрос, что бы для каждой записи из первой таблицы выводиться только одна запись из второй таблицы в которой значение из определенного столбца наибольшее?

Последний раз редактировалось Den-is, 22.12.2011 в 10:25.
Ответить с цитированием
  #2  
Старый 22.12.2011, 10:24
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Ты уже спрашивал...
__________________
Google в помощь
Ответить с цитированием
  #3  
Старый 22.12.2011, 10:27
Pyro Pyro вне форума
Так проходящий
 
Регистрация: 18.07.2011
Сообщения: 805
Версия Delphi: 7Lite
Репутация: 6063
По умолчанию

[>order by + limit<]
чёт я тупанул

Последний раз редактировалось Pyro, 22.12.2011 в 11:32.
Ответить с цитированием
  #4  
Старый 22.12.2011, 10:31
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Цитата:
Сообщение от Pyro
order by + limit
Что ты этим хотел сказать?
__________________
Google в помощь
Ответить с цитированием
  #5  
Старый 22.12.2011, 10:38
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

не не, в прошлый раз было все по другому.
Ответить с цитированием
  #6  
Старый 22.12.2011, 10:39
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

в этот раз нужно чтоб не просто выдавало максимальное значение а именно вся строка в которой это значение
Ответить с цитированием
  #7  
Старый 22.12.2011, 10:48
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

если используешь "max" например max(tab2.at1) то максимальное значение выдается в отдельном столбце "expr1001" а ме нужно что бы он выводил всю строку
Ответить с цитированием
  #8  
Старый 22.12.2011, 11:22
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

может как то сделать запрос с под запросом?
Ответить с цитированием
  #9  
Старый 22.12.2011, 11:29
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Цитата:
Сообщение от Den-is
может как то сделать запрос с под запросом?
Да тут скорее всего без подзапроса никак не обойтись:
Код:
select tab2.* from
(select tab1.nomer, max(tab2.at1) m
  from tab1, tab2
 where tab1.nomer = tab2.nomer
 group by tab1.nomer) A, tab2
 where A.nomer = tab2.nomer
   and A.m = tab2.at1
 order by nomer
P.S. Если запрос тупой прошу прощения, давно уже не спал
__________________
Google в помощь
Ответить с цитированием
  #10  
Старый 22.12.2011, 12:07
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

да главное чтоб работал!)))
а пока что то вотБезымянный.jpg
Ответить с цитированием
  #11  
Старый 22.12.2011, 12:10
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Цитата:
Сообщение от Den-is
да главное чтоб работал!)))
Блин, привык по работе на pl/sql запросы собирать. Конечно же:
Код:
max(tab2.at1) as m
__________________
Google в помощь
Ответить с цитированием
  #12  
Старый 22.12.2011, 12:29
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

Классно! Спасибо!!!!!!!!!!!!!!!
Ответить с цитированием
  #13  
Старый 22.12.2011, 12:56
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

слушай ну и в завершении подскажи а что нужно дописать, что бы по мимо этого на экране показывались еще и несколько столбцов из первой таблицы: "tab1.familia" "tab1.ima" "tab1.professia" "tab1.udostoverenie" а затем то что уже есть?
Ответить с цитированием
  #14  
Старый 22.12.2011, 13:43
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Дополни просто свой подзапрос в чем проблема то? Тут главное понимать что подзапрос выступает в роли самостоятельной таблицы.
Код:
select A.что-то, A.что-тоЕще, tab2.*
from
(select tab1.nomer, tab1.что-то, tab1.что-тоЕще, max(tab2.at1) m
  from tab1, tab2
 where tab1.nomer = tab2.nomer
 group by tab1.nomer, tab1.что-то, tab1.что-тоЕще) A, tab2
 where A.nomer = tab2.nomer
   and A.m = tab2.at1
 order by nomer
А вообще пройди какой-нибудь курс по созданию sql-запросов. Я так понимаю тебе еще пригодится.
__________________
Google в помощь
Ответить с цитированием
  #15  
Старый 22.12.2011, 14:38
Den-is Den-is вне форума
Новичок
 
Регистрация: 07.10.2011
Сообщения: 66
Репутация: 10
По умолчанию

хорошо спасибо
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 10:16.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter