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

C++빌더 팁&트릭
C++Builder Programming Tip&Tricks
[347] [DB] 동적 SQL 에서 필드 이름이나 테이블 이름 바꾸기
타락천사 [rain622] 6856 읽음    2002-06-15 19:45
안녕하세여. 타락임다..

오래전부터 알고는 있었지만, 쓸일은 없을 것이라고 생각했었습니다. 그런데 오늘 개발하며 그 기능이 필요해 써보니 생각보다 유용하더군여. Room0 부터 Room9 까지 테이블에 있는데 동적으로 테이블을 선택해서 써야 할 필요가 생겼습니다.

아래가 설명입니다. C 코드가 아니라 죄송합니다. 후다닥~~

SQL 질의문 안의 필드 이름이나 테이블 이름 같은 단어들은 치환할 수 없습니다. SQL 서버가 그런 기능을 지원하지 않기 때문입니다.

동적 SQL(이전에 올린 팁 참조) 에서 필드 이름이나 테이블 이름을 동적으로 변경시킬 방법이 있습니다.

Format() 함수를 사용하면 됩니다.

const
  sqlHistory = 'INSERT Room%d (One, Two, Three) VALUES (%s, %s, %s)';
begin
............
  with DMMain do
  begin
    qryHistory.SQL.Clear;
    qryHistory.SQL.Text := Format(sqlHistory, [nNo, ID[0], ID[1], ID[2]]);
    qryHistory.ExecSQL;
  end;
..................

즐푸하세여...

타락천사..

+ -

관련 글 리스트
347 [DB] 동적 SQL 에서 필드 이름이나 테이블 이름 바꾸기 타락천사 6856 2002/06/15
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.