C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[12409] Table1에 여러가지 .db파일이 있는데 이것을 하나하나 구분하는 인덱스 같은 기능이 있나요?
heartsim [] 646 읽음    2001-11-07 12:03
안녕하세요.
빌더를 얼마 시작한지 않되는 초보입니다.
막히는 부분이 있어서요.

Table1에서 fix.db, dcref.db 등등 여러 파일을 불러서 DBgrid에 표시하는데
이 여러 파일을 구분하는 인덱스 같은 기능이 있나요?
어떤 경우 버튼을 누르면fix.db데이터를 GBgrid화면에 표시하고 또 버튼을 누르면
dcref.db데이터를 화면에 보이게 한 후,
만일 dcref.db데이터가 선택되어 화면에 보인 경우, 필드를 선택해서 값을 얻을려고 합니다.

그런데 다음과 같은 로직이 잘 안되서요.
자꾸 strlen(Table1->TableName.c_str())에서 에러가 나는 군요
      Constant expression required

특별히 파일을 구별할 수 있는 인덱스 기능이 없어서 나름대로 strlen을 써서 그 값으로 파일을 구분할려고 하는데 힘드네요.제가 strlen을 잘 못 썼나요? 이 로직으로 해도 된다면 문법적인 오류가 어디인지 체크를 좀 부탁드립니다.

.
.
void __fastcall TForm1::DBGrid1CellClick(TColumn *Column)
{

        switch(strlen(Table1->TableName.c_str()))
        {
                case strlen("fix.db"):  //에러가 나는 부분 "Constant expression required"
                   if(strchr(Table1->FieldByName("50")->AsString.c_str(),'&')!=NULL)
                   {
                                     중간생략.........
                   }
                   else
                   {
                                     중간생략.........
                   }
                   break;
       
                case strlen("dcref.db"): //에러가 나는 부분

                   if(strchr(Table1->FieldByName("9")->AsString.c_str(),'&')!=NULL)
                   {
                        sprintf(str_read,"%s",Table1->FieldByName("9")->AsString);
                        sprintf(str_write,"%s",str_read+2);
                        Edit5->Text=str_write;  //주의 요망^^ 고생 엄청 했음
                        UpDown1->Position=AnsiString("0x"+Edit5->Text).ToInt();
                        Label9->Caption="&&H";
                    }
                    else
                    {
                        Edit5->Text=Table1->FieldByName("9")->AsString;
                        UpDown1->Position=AnsiString(Edit5->Text).ToInt();
                        Label9->Caption='\0';
                    }
                    break;
        }
        Label8->Caption=Table1->FieldByName("Name")->AsString;
        Edit4->Text=Table1->FieldByName("Function")->AsString;
}

좋은 하루 되세요.^^

from heartsim

+ -

관련 글 리스트
12409 Table1에 여러가지 .db파일이 있는데 이것을 하나하나 구분하는 인덱스 같은 기능이 있나요? heartsim 646 2001/11/07
12414     Re:Table1에 여러가지 .db파일이 있는데 이것을 하나하나 구분하는 인덱스 같은 기능이 있나요? 로렌조 699 2001/11/07
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.