Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.06.27;
Скачать: CL | DM;

Вниз

Фильтрация повторяющихся значений   Найти похожие ветки 

 
AlexanderSK   (2004-06-03 17:50) [0]

Есть TClientDataSet, поля р1, р2.
Причем значения р1 - повторяются (по 2-4 записи с одинм и тем же значением р1, при этом р2 для них разные).
Нужно получить список значений р1 (без повторов!)

Подскажите, пожалуйста, как это лучше сделать?


 
Курдль ©   (2004-06-03 17:52) [1]

Только не TClientDataSet или каким угодно другим Т..., а ТЗапросом.


 
Sandman25 ©   (2004-06-03 17:58) [2]

Если получить там же, то можно установить IndexFieldNames, а потом пробежаться в цикле и удалить повторяющиеся.


 
Jiny   (2004-06-03 18:04) [3]

>Только не TClientDataSet или каким угодно другим Т..., а ТЗапросом
может быть надо было сказать каким именно запросом ?

select distinct p1 from имя таблицы


 
AlexsanderSK   (2004-06-03 18:07) [4]

>Курдль ©  (03.06.04 17:52) [1]
>Jiny  (03.06.04 18:04) [3]
Да нет! Суть как раз в том, чтобы к БД не обращаться!


 
Jiny   (2004-06-03 18:21) [5]

попробуй так
var
MyDIm: array of String;
i,i2: integer;
tmpText: string;;
Begin
 SetLength(MyDim,Tdataset.RecordCount);
 For i:=0 to Tdataset.RecordCount-1 do
 begin
   TmpText:=Tdataset.FieldByname("field").AsString;
   For i2:=0 to i do
   begin
     If AnsiUpperCase(TmpText)=AnsiUppercase(MYDim) then
       break;
     else
     Begin
       MyDim[i]:=TmpText;
       break;
     end;
   end;
    Tdataset.FindNext  
 end;
end;


 
Jiny   (2004-06-03 18:22) [6]

попробуй так
var
MyDIm: array of String;
i,i2: integer;
tmpText: string;;
Begin
 SetLength(MyDim,Tdataset.RecordCount);
 For i:=0 to Tdataset.RecordCount-1 do
 begin
   TmpText:=Tdataset.FieldByname("field").AsString;
   For i2:=0 to i do
   begin
     If AnsiUpperCase(TmpText)=AnsiUppercase(MYDim[i2]) then
       break;
     else
       MyDim[i]:=TmpText;
   end;
    Tdataset.FindNext  
 end;
end;


 
Jiny   (2004-06-03 18:27) [7]

Ошибочка Вышла, не успел отменить отправку текста,
попробуй так
var
MyDIm: array of String;
i,i2: integer;
tmpText: string;;
Result: boolean;
Begin
SetLength(MyDim,Tdataset.RecordCount);
For i:=0 to Tdataset.RecordCount-1 do
begin
  TmpText:=Tdataset.FieldByname("field").AsString;
  For i2:=0 to i do
    If AnsiUpperCase(TmpText)=AnsiUppercase(MYDim[i2]) then
      Result:=false else result:=true;

   If result then MyDim[i]:=TmpText;
 
   Tdataset.FindNext  
end;
MyDim:=nil;
end;
Потом пройдешься циклом по не нулевым значениям


 
Anatoly Podgoretsky ©   (2004-06-03 19:53) [8]

AlexsanderSK   (03.06.04 18:07) [4]
Духом святыс что ли?



Страницы: 1 вся ветка

Текущий архив: 2004.06.27;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.045 c
1-1087275595
try
2004-06-15 08:59
2004.06.27
Извлечение имени папки диска


3-1086058303
ИМХО
2004-06-01 06:51
2004.06.27
Открыть в FoxPro with memo в Delphi


1-1087069935
oleg_SYS
2004-06-12 23:52
2004.06.27
Пункт "создать"


3-1085972910
Victor_A
2004-05-31 07:08
2004.06.27
Как узнать, что у базы данных сменили пароль


14-1086958686
cyborg
2004-06-11 16:58
2004.06.27
Хостинг