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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 05.05.2011, 18:04
iliabest iliabest вне форума
Прохожий
 
Регистрация: 05.05.2011
Сообщения: 2
Репутация: 10
По умолчанию Как вывести значение из DBGrid в переменную

Помогите пожалуйста решить задачу, уже несколько дней мучаюсь и никак не могу понять в чем проблема. У меня DBGrid визуализирует данные таблицы SOKPO, которая содержит 1 столбец с именем P_N, он содержит большое число записей( 93 000 ). Мне нужно чтобы по щелчку кнопки Button1 Итоговые значения записывались в txt файл.
(Я вывел данные по возрастанию "ORDER BY P_N");
Например.
В стоблце P_N, номер 224 встретился 10 раз, а номер 225 встретился 15 раз.
Надо что в текстовый файл попали такие значения :

224 10
225 15

(В итоги 93 000 строк должны превратиться в 69(без повторений))
Умоляю помогите..

Код:
procedure TForm1.Button1Click(Sender: TObject);
var
d:textfile;
k,i,n:Integer;
v:integer;
PN,P_N:string;
begin
AssignFile(d,'Итог.txt');
Append(d);
DBGrid1.DataSource.DataSet.DisableControls;
DBGrid1.DataSource.DataSet.First;
n:=1;
k:=1;
 with DBGrid1 do
  begin
    while not DataSource.DataSet.Eof do
     begin
       for v:=1 to Datasource.DataSet.RecordCount-1 do
        begin
        PN:=Fields[v].AsString;
        Datasource.DataSet.Next;
        P_N:=Fields[v].AsString;
       if PN=P_N then
        begin
          n:=n+1;
          DataSource.DataSet.Next;
        end
       else
        begin
         Write(d,PN,' ');
         Write(d,n, ' ');
         Writeln(d);
         n:=0;
         DataSource.DataSet.Next;
        end;
       DataSource.DataSet.Next;
      end;
      DataSource.DataSet.Next;
     end;
     CloseFile(d);
  end;

 DBGrid1.DataSource.DataSet.EnableControls;
end;
Админ: Пользуемся тегами для оформления кода!

Последний раз редактировалось Admin, 05.05.2011 в 18:09.
Ответить с цитированием
  #2  
Старый 05.05.2011, 18:43
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Под дистинкт загнать. И еще каунт запользовать. В запросе все это сделать можно.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #3  
Старый 05.05.2011, 20:11
iliabest iliabest вне форума
Прохожий
 
Регистрация: 05.05.2011
Сообщения: 2
Репутация: 10
По умолчанию

Да но мне нужно чтобы данные не повторялись в текстовом файле..
Можешь пожалуйста код показать?
Ответить с цитированием
  #4  
Старый 06.05.2011, 09:46
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Может это:
Код:
select t.p_n, count(t.p_n)
  from sokpo t
group by t.p_n
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter