본문 바로가기
마루아라는 개발쟁이/MS.SQL

DROP IF EXISTIS

by 마루아라 이야기 2024. 8. 22.

DROP IF EXISTS 구문은 SQL Server에서 객체를 삭제할 때 유용하게 사용됩니다.

이 구문을 통해 특정 객체가 존재할 경우에만 삭제할 수 있어, 코드의 안정성을 높일 수 있습니다.

아래는 DROP IF EXISTS 사용 예시와 설명입니다.

 

예시

DROP TABLE IF EXISTS dbo.table;
GO

위 구문은 dbo.table 테이블이 존재하는 경우에만 해당 테이블을 삭제합니다. 이 방법은 이전의 IF OBJECT_ID 또는 IF EXISTS 구문보다 간단하고 가독성이 좋습니다.

 

이전의 방법

 

IF OBJECT_ID('dbo.table', 'U') IS NOT NULL
DROP TABLE dbo.table;
IF EXISTS (SELECT * FROM sys.objects WHERE name = 'table' and type = 'U')
DROP TABLE dbo.table

 

지원하는 개체 타입

DROP IF EXISTS는 다양한 개체 타입에 대해 지원됩니다. 여기에는 다음과 같은 것들이 포함됩니다:

  • TABLE
  • VIEW
  • PROCEDURE
  • FUNCTION
  • INDEX
  • TRIGGER
  • SEQUENCE
  • USER, 등

주의사항

  • 모든 DROP 문에서 IF EXISTS가 지원되는 것은 아닙니다. 예를 들어, DROP LOGIN 구문은 IF EXISTS를 지원하지 않으므로, 이러한 경우에는 기존의 조건문을 사용해야 합니다.
  • MSDN 문서에서 각 개체 타입의 DROP 명령어에 대한 지원 여부를 확인하는 것이 좋습니다.

이런 방식으로 DROP IF EXISTS를 활용하면 코드가 간결해지고, 객체의 존재 여부를 체크하는 로직을 간단히 처리할 수 있습니다.

728x90
반응형
LIST