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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.08.2007, 23:03
Sparxx Sparxx вне форума
Прохожий
 
Регистрация: 14.08.2007
Сообщения: 4
Репутация: 10
Вопрос Помагайте уже..

Есть БД.
Нужно найти в столбце из чисел максимум..
Как это можно сделать не через SQL?
Подскажите. Заранее спасибо.
Ответить с цитированием
  #2  
Старый 15.08.2007, 14:07
Sparxx Sparxx вне форума
Прохожий
 
Регистрация: 14.08.2007
Сообщения: 4
Репутация: 10
По умолчанию

Неужели никто не подскажет?
Очень надо.. Никак не врублюсь как это сделать и в литературе не могу найти.
Ответить с цитированием
  #3  
Старый 15.08.2007, 18:04
Аватар для 4erep_88
4erep_88 4erep_88 вне форума
Новичок
 
Регистрация: 18.07.2007
Сообщения: 51
Репутация: 15
По умолчанию

Способ 1
Упорядочи строки по возрастанию элементов в этом столбце. Тогда в последней строке будет максимальный элемент.
Способ 2
Тупо сравниваешь между собой элементы во всех строках.
Ответить с цитированием
  #4  
Старый 15.08.2007, 18:07
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

Можно через TTable. А максимум считать в Delphi. Но советуют, чтобы обработка велась сервером БД. Почему нельзя сделать запрос?
Ответить с цитированием
  #5  
Старый 15.08.2007, 18:29
Аватар для mav_c
mav_c mav_c вне форума
Активный
 
Регистрация: 26.03.2007
Адрес: Москва
Сообщения: 287
Репутация: 30
По умолчанию

Цитата:
Сообщение от Sparxx
Есть БД.
Нужно найти в столбце из чисел максимум..
Как это можно сделать не через SQL?
Подскажите. Заранее спасибо.
А если построить индекс по этому полю? И потом считать последнюю строку?
__________________
---------------------------------------------
Программирование - не профессия, а стиль жизни
Ответить с цитированием
  #6  
Старый 15.08.2007, 22:12
Sparxx Sparxx вне форума
Прохожий
 
Регистрация: 14.08.2007
Сообщения: 4
Репутация: 10
По умолчанию

Можно дать запрос, но он только отображает максимум.. а если я хочу его определить в новую переменную и дальше с ним работать, как тогда?

Повторюсь.. Обыкновенная БД в Дельфи написанная через Access.
В ней столбик с числами. Я хочу в этом столбце найти максимум и дальше с ним работать. Еслиб бы была обыкновенная таблица StringGrid, то без проблем организовал бы цикл.. А так что то не получается, не знаю как получить доступ к каждой ячейке столбца чтобы написать нужный цикл. А через SQL конечно он мне отображает..
Я новичок.. но вроде не запутанно написал
Ответить с цитированием
  #7  
Старый 16.08.2007, 05:32
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Пусть, MainConnection:TADOConnection - это твое соединене с базой, тогда:
Код:
function GetFldMax(aTableName,aFieldName:String):Integer;
var
  Q:TADOQuery;
begin
  Q:=TADOQuery.Create(nil);
  with Q do
    begin
      Connection:=MainConnection;
      SQL.Text:=Format('SELECT MAX([%s]) as MAXIMUM FROM [%s]',[aFieldName,aTableName])
      Open;
      Result:=FieldByName('MAXIMUM').AsInteger;
      Close;
      Free;
    end;
end;
в функцию передается имя таблицы и имя поля по которому нужно получить максимум, как видно из кода поле должно быть целое.
Это, так сказать, скелет функции, тут еще требуется сделать обработчик ошибок.

пример использования:
Код:
var
  MyMax:Integer;
begin
  MyMax:=GetFldMax('Table1','Field1');
  ...
end;
Ответить с цитированием
  #8  
Старый 16.08.2007, 18:30
Аватар для mav_c
mav_c mav_c вне форума
Активный
 
Регистрация: 26.03.2007
Адрес: Москва
Сообщения: 287
Репутация: 30
По умолчанию

Цитата:
Сообщение от Sparxx
Можно дать запрос, но он только отображает максимум.. а если я хочу его определить в новую переменную и дальше с ним работать, как тогда?

Повторюсь.. Обыкновенная БД в Дельфи написанная через Access.
В ней столбик с числами. Я хочу в этом столбце найти максимум и дальше с ним работать. Еслиб бы была обыкновенная таблица StringGrid, то без проблем организовал бы цикл.. А так что то не получается, не знаю как получить доступ к каждой ячейке столбца чтобы написать нужный цикл. А через SQL конечно он мне отображает..
Я новичок.. но вроде не запутанно написал

Ну уж если доступ к каждой ячейке столбца тогда:
Код:
...
while (not ADOTable1.Eof) do
 begin
  ADOTable1.FieldByName('имя_поля').AsInteger;//Вот твоё поле!
  ADOTable1.Next();
 end;
...
__________________
---------------------------------------------
Программирование - не профессия, а стиль жизни
Ответить с цитированием
  #9  
Старый 12.09.2007, 18:35
Elv Elv вне форума
Прохожий
 
Регистрация: 11.09.2007
Сообщения: 17
Репутация: 10
По умолчанию

Цитата:
Сообщение от Sparxx
Можно дать запрос, но он только отображает максимум.. а если я хочу его определить в новую переменную и дальше с ним работать, как тогда?
"Моя переменная" := SQL.FieldByName(Max).AsInteger;

Цитата:
Сообщение от Sparxx
В ней столбик с числами. Я хочу в этом столбце найти максимум и дальше с ним работать.
Надеюсь не id получаешь?
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter