::: 델파이 Tip&Trick :::

델파이 Tip&Trick 성격에 맞지 않는 광고,비방,질문의 글은 즉시 삭제하며
내용을 복사하여 사용할 경우 반드시 이곳(http://www.howto.pe.kr)을 출처로 명시하여 주세요


Category

  김영대(2003-03-07 09:13:35, Hit : 3947, Vote : 886
 동적으로 SELECT의 GROUP BY 문 만들기

> 혜정이 wrote:
> 안녕하세요?
>
> 여러개의 항목이 있을때 이걸 group by를 하는데...
> 몇개를 선택해서 group by할 수 있는 방법이 있나요?
> 예를 들면...
> 항목이 a,b,c,d,e,f(필드들)가 있을때...
>
> 런타임시 a,b를 선택해서(체크박스이용) sql을 날리면...
> sql.add('select a,b,sum(x) from aaa');
> sql.add('group by a,b');
> 위와같은 문장이 실행되어야 해요...
>
> 선택할 수 있는 갯수는 여러개가 될수 있어요..
> 예를 들면 c,d,f세개를 선택할 수도 있고 말이에요...
>
> 너무 경우의 수가 많아서...
> 무슨 방법이 없을까요?
> decisioncube를 쓰면 되는데...쓸수 없는 상황이라서...쩝쩝...
>
> 꼭 좀 알려줘요...
>
> 그럼 안녕히 계세요..
>

안녕하세요  김영대입니다
SQL문의 조합은 사실 문자열 조작이기 때문에 만드는 방법은 다양합니다

그런데 질문하신 GROUP BY 가 들어가는 SELECT문은 고려할 사항이
한가지 있습니다
"Groups within Groups"
즉 GROUP BY 뒤에 나열한 필드들은 기본적으로 sort order
가 있기 때문에 우선순위를 생각해야 합니다

아래 예제를 한번 돌려보세요
만드는 방법은 폼위에 나란히 배열한 CheckBox 5개, Button 하나,
Memo 하나를 올려놓습니다
그다음에 설정할 프로퍼티는 소스에서 하므로 설정할 필요가 없이
바로 실행하시면 됩니다

실행 후 각 CheckBox 를 클릭하시면 Memo에 SELECT문장이 생성됩니다
여기에 우선순위를 고려해서...
우선순위는 나중에 check 한것이 높게 설정됩니다

그럼 수고하세요


unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls;

type
  TForm1 = class(TForm)
    CheckBox1: TCheckBox;
    CheckBox2: TCheckBox;
    CheckBox3: TCheckBox;
    CheckBox4: TCheckBox;
    CheckBox5: TCheckBox;
    Memo1: TMemo;
    procedure FormCreate(Sender: TObject);
    procedure FormCloseQuery(Sender: TObject; var CanClose: Boolean);
    procedure CheckBoxAllClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;
  CheckBoxList: TStringList;

implementation
{$R *.DFM}

procedure TForm1.FormCreate(Sender: TObject);
var
  i: Integer;
begin
  CheckBoxList := TStringList.Create;
  // 테이블의 필드명과 그 필드를 나타내는 CheckBox의 연관관계를 나타내어 저장한다
  CheckBoxList.AddObject('a', TObject(CheckBox1));
  CheckBoxList.AddObject('b', TObject(CheckBox2));
  CheckBoxList.AddObject('c', TObject(CheckBox3));
  CheckBoxList.AddObject('d', TObject(CheckBox4));
  CheckBoxList.AddObject('e', TObject(CheckBox5));

  for i := 0 to CheckBoxList.Count-1 do
  begin
    // 각 CheckBox의 Tag에 초기치 0를 넣는다
    TCheckBox(CheckBoxList.Objects[i]).Tag := 0;
    // 각 CheckBox의 ShowHint를 활성화 한다
    TCheckBox(CheckBoxList.Objects[i]).ShowHint := True;
    // 각 CheckBox의 OnClick 이벤트 할당
    TCheckBox(CheckBoxList.Objects[i]).OnClick := CheckBoxAllClick;
  end;
end;

procedure TForm1.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin
  CheckBoxList.Free;
end;

procedure TForm1.CheckBoxAllClick(Sender: TObject);
var
  i, j, CheckedCount: Integer;
begin
  if TCheckBox(Sender).Checked then
  begin
    // 가장 최근에 Check된 CheckBox의 우선순위를 1 로 나머지는 1씩 증가
    TCheckBox(Sender).Tag  := 1;
    TCheckBox(Sender).Hint := IntToStr(TCheckBox(Sender).Tag) + ' 순위';

    for i := 0 to CheckBoxList.Count-1 do
      if (TCheckBox(CheckBoxList.Objects[i]) <> TCheckBox(Sender)) and
         (TCheckBox(CheckBoxList.Objects[i]).Tag > 0) then
      begin
        TCheckBox(CheckBoxList.Objects[i]).Tag  := TCheckBox(CheckBoxList.Objects[i]).Tag + 1;
        TCheckBox(CheckBoxList.Objects[i]).Hint := IntToStr(TCheckBox(CheckBoxList.Objects[i]).Tag) + ' 순위';
      end;
  end
  else // UnChecked
  begin
    // 모든 Check된 CheckBox의 우선순위를 1씩 감소
    for i := 0 to CheckBoxList.Count-1 do
      if TCheckBox(CheckBoxList.Objects[i]).Tag > TCheckBox(Sender).Tag then
      begin
        TCheckBox(CheckBoxList.Objects[i]).Tag  := TCheckBox(CheckBoxList.Objects[i]).Tag - 1;
        TCheckBox(CheckBoxList.Objects[i]).Hint := IntToStr(TCheckBox(CheckBoxList.Objects[i]).Tag) + ' 순위';
      end;

    TCheckBox(Sender).Tag  := 0;
    TCheckBox(Sender).Hint := '';
  end;

  // Checked된것이 없으면 SELECT를 만들지 않는다
  Memo1.Clear;
  CheckedCount := 0;
  for i := 0 to CheckBoxList.Count-1 do
    if TCheckBox(CheckBoxList.Objects[i]).Tag > 0 then
       Inc(CheckedCount);
  if CheckedCount = 0 then
    System.Exit;

  Memo1.Lines.Add('SELECT');
  // 우선순위에 따라 필드의 위치를 결정
  for i := 1 to CheckBoxList.Count do // 순위
    for j := 0 to CheckBoxList.Count-1 do
      if TCheckBox(CheckBoxList.Objects[j]).Tag = i then
        Memo1.Lines.Add(CheckBoxList.Strings[j]+',');
  // 맨 마지막 comma를 제거한다
  Memo1.Lines[Memo1.Lines.Count-1] :=
      Copy(Memo1.Lines[Memo1.Lines.Count-1], 1, Length(Memo1.Lines[Memo1.Lines.Count-1])-1);

  Memo1.Lines.Add('FROM table');
  Memo1.Lines.Add('GROUP BY');
  // 우선순위에 따라 필드의 위치를 결정
  for i := 1 to CheckBoxList.Count do // 순위
    for j := 0 to CheckBoxList.Count-1 do
      if TCheckBox(CheckBoxList.Objects[j]).Tag = i then
        Memo1.Lines.Add(CheckBoxList.Strings[j]+',');
  // 맨 마지막 comma를 제거한다
  Memo1.Lines[Memo1.Lines.Count-1] :=
      Copy(Memo1.Lines[Memo1.Lines.Count-1], 1, Length(Memo1.Lines[Memo1.Lines.Count-1])-1);
end;

end.





571   [일반/컴포넌트] 레지스트리를 사용하는 사용자 함수 만들어 보기  구창민 2003/03/14 4594 1034
570   [윈도우즈 API] 레지스트리가 변경된 사실을 알리려면...  김영대 2003/03/06 4291 1153
569   [윈도우즈 API] 레지스트리(registry)를 바꾼후...  김영대 2003/03/05 4407 1186
568   [윈도우즈 API] 레지스트리 전체 검색하기  김영대 2003/03/07 3930 1079
567   [윈도우즈 API] 떠있는 모든 Microsoft Internet Explorer 죽이기  김영대 2003/03/29 4466 1262
566   [COM/OLE] 떠있는 모든 Microsoft Internet Explorer 의 html 불러오기  김영대 2003/03/30 5538 1358
565   [COM/OLE] 떠있는 모든 Internet Explorer 를 강제 Refresh 시키기  김영대 2004/09/20 4789 1228
564   [윈도우즈 API] 떠다니는 윈도우  김영대 2003/03/05 4335 1133
563   [시스템] 떠 있는 프로그램 죽이기...  김영대 2003/03/04 5609 1372
562   [시스템] 디스플레이 어댑터 목록 구하기  김영대 2004/08/11 4423 1173
561   [시스템] 디스크의 남은 용량 등등...  김영대 2003/03/05 4972 1348
560   [윈도우즈 API] 디스크 캐쉬의 파일을 디스크로 쓰기  김영대 2003/03/05 4017 1078
559   [시스템] 디스크 드라이브의 현재상태 얻기  김영대 2003/03/05 3442 966
558   [일반/컴포넌트] 디렉토리명 바꾸기/이동 하기  김영대 2003/03/07 4996 1513
557   [윈도우즈 API] 디렉토리나 파일의 속성(변경/생성/사용한 날짜, 특성) 바꾸기  김영대 2004/12/08 9872 1369
556   [일반/컴포넌트] 디렉토리 삭제루틴(하부디렉토리 몽땅)  김영대 2003/03/06 3466 952
555   [일반/컴포넌트] 디렉토리 복사루틴 (하부디렉토리 까지 몽땅)  김영대 2003/03/06 4518 1049
554   [일반/컴포넌트] 디렉토리 변동사항을 탐색기에 알리기  김영대 2003/03/07 5007 1532
553   [일반/컴포넌트] 디렉토리 검색하여 파일 찾기  김영대 2003/03/05 4912 1432
552   [시스템] 드라이브 포맷(Format) API 함수  김영대 2003/03/04 4706 1278
551   [일반/컴포넌트] 둥근 풍선도움말을 나타내주는 콤포넌트  김영대 2003/03/05 3001 731
550   [시스템] 두개의 파일이 완전히 동일한지 검사하기2  김영대 2003/03/07 3207 925
549   [시스템] 두개의 파일이 완전히 동일한지 검사하기(CRC32)  김영대 2003/03/05 4435 1047
548   [일반/컴포넌트] 두개의 StringGrid sync 마추기  김영대 2003/03/07 3523 966
547   [일반/컴포넌트] 두개의 RichEdit 사이에 내용 복사하기  김영대 2003/03/06 5359 1259
546   [알고리즘] 두 문자열의 유사도 검사하기  김영대 2004/09/04 4963 1117
545   [일반/컴포넌트] 두 StringGrid 의 scroll 을 동기화 시키기  김영대 2003/03/07 4254 1027
544   [일반/컴포넌트] 동적으로 프로젝트의 Main form 바꾸기  김영대 2003/04/11 4644 1141
543   [데이터베이스] 동적으로 인덱스 만들기  김영대 2003/03/06 4163 1066
542   [일반/컴포넌트] 동적으로 생성한 TLabel 마우스로 이동시키기  김영대 2004/08/04 6261 1846
541   [일반/컴포넌트] 동적으로 메뉴(memu)에 Item 추가하기  김영대 2003/03/06 4660 1252
  [데이터베이스] 동적으로 SELECT의 GROUP BY 문 만들기  김영대 2003/03/07 3947 886
539   [일반/컴포넌트] 동적으로 class의 instance 만들기  김영대 2003/03/06 3732 1045
538   [일반/컴포넌트] 도넛(Doughnut) 모양의 폼 만들기  김영대 2004/08/09 4303 1064
537   [윈도우즈 API] 도구모음 Bar는 어떻게 만드는지...  김영대 2003/03/04 4680 1325
536   [일반/컴포넌트] 델파이의 Object Inspector 모방  김영대 2003/03/06 3105 761
535   [윈도우즈 API] 델파이에서 시간을 기다리는 함수  김영대 2003/03/04 5797 1346
534   [일반/컴포넌트] 델파이안에 익스플로러 삽입  신훈재 2003/03/10 5757 1024
533   [시스템] 델파이로 DOS 프로그램(Console application) 만들기  김영대 2003/03/06 8746 2829
532   [일반/컴포넌트] 델파이 통합개발환경(IDE) 에 관한 몇가지 Tip  김영대 2003/03/04 5338 1431

[이전 10개] [1].. 11 [12][13][14][15][16][17][18][19][20]..[25] [다음 10개]
 

Copyright 1999-2019 Zeroboard / skin by zero