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

FireBird Q&A
[3472] Re:특정테이블 필드가 있는지 또는 특정프로시져가 있는지 유무를 체크 하는법을 알고싶습니다.
까막.윤창희 [ggamagui] 3251 읽음    2010-06-22 08:58
궁금환자 님이 쓰신 글 :
: if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[프로시져명]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
: drop procedure [dbo].[프로시져명]
: GO
: 이런식 아님
:
: if not exists(select * from information_schema.columns where TABLE_NAME='테이블명' and COLUMN_NAME='컬럼명')
: BEGIN
: ALTER TABLE [dbo].[테이블명] ADD [컬럼명]image
: END
: GO
: 이런식으로
:
: 특정테이블에 필드유무를 체크하고 필드가 존재하지 않을경우에만 필드추가를 하는 스크립트를 만들려고 합니다.
:
: MS-SQL에서는  위와 같은 방법으로 하면되는데 파이어보드에서는 어떻게 하는지 궁금합니다.
:
: 위의건 프로시져존재유무를 따지는 스크립트인데 위의거도 마찬가지로 파이어버드에 적용하는 방법이 궁금합니다.

안녕하세요. 까막입니다.

테이블 관련해서...
SELECT F.*                                                                
FROM   RDB$RELATION_FIELDS  F                                             
                            INNER JOIN             RDB$RELATIONS         R
                        ON (F.RDB$RELATION_NAME = R.RDB$RELATION_NAME)    
WHERE  F.RDB$RELATION_NAME = 테이블명
AND    F.RDB$FIELD_NAME    = 필드명


프로시져 관련해서...
SELECT *                                                                       
FROM   RDB$PROCEDURES  P                                                       
                            INNER JOIN             RDB$PROCEDURE_PARAMETERS   F
                        ON (P.RDB$PROCEDURE_NAME = F.RDB$PROCEDURE_NAME)       
WHERE  P.RDB$PROCEDURE_NAME = 프로시져명
AND    F.RDB$PARAMETER_NAME = 파라미터명


이렇게 하시면 됩니다.

이외에도 RDB$ 로 시작하는 것들이 많이 있으니까 찾아 보시면 많은 도움이 되실 겁니다.



                                                            혼이 살아 있을까.... 대한민국.

+ -

관련 글 리스트
3468 특정테이블 필드가 있는지 또는 특정프로시져가 있는지 유무를 체크 하는법을 알고싶습니다. 궁금환자 2875 2010/06/21
3472     Re:특정테이블 필드가 있는지 또는 특정프로시져가 있는지 유무를 체크 하는법을 알고싶습니다. 까막.윤창희 3251 2010/06/22
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.