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
[22255] DB manage Module에서 . . . .
장성호 [nasilso] 574 읽음    2002-10-25 18:18

제가 지금 database에 manage하는 class를 설계하고 있습니다.

생성자에서 connection string 을 받아서 database를 설정하구요

메소드로 sql문을 받아서

select하는 함수

그냥 update insert하는 exec함수 등이 있습니다.

문제는 update 나 insert함수는 return을 bool로 하면되는데

select함수일경우 return을 TDataSource로 하고싶습니다.
그런데 이게 잘안되네요

간단히 class 코드를 적으면....

class CDBConnection
{
private:
   TDatabase   *Database;
   TQuery      *Query;
   TDataSource *DataSource;
public:
   __fastcall CDBConnection(TDatabase *inDatabase, TQuery *inQuery, TDataSource *inDataSource);

   void __fastcall DBOpen(AnsiString sql);
   TDataSource __fastcall DBOpen(TQuery *query, AnsiString sql);
   void __fastcall DBExec(AnsiString sql);

};

제가 원하는 것은 위에서   
TDataSource __fastcall DBOpen(TQuery *query, AnsiString sql);
메소드를 어떻게 설계하냐는 것이죠~!

좀더 구체적으로 db  query가 문제가 아니라
query해온 datasource를 return하지를 못하고 있습니다

return하려면 new로 생성을 해야된다나 어쩐다나... error 문에 그렇게 나오던데
TDataSource를  new로 생성하려니 TComponent 의 형의 Owner를 넘겨줘야 되더군요

TDataSource __fastcall DBOpen(TQuery *query, AnsiString sql)
{
TComponent *obj;
TDataSource *source=new TDataSource(obj);

//쿼리문 생략

return source;  //이부분에서 계속 에러남

}

위와같이 하니 계속 에러가 납니다.

읽어주셔서 감사합니다.
좋은 답변 기대하겠습니다.
샬롬~!

+ -

관련 글 리스트
22255 DB manage Module에서 . . . . 장성호 574 2002/10/25
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.