다음을 통해 공유


어셈블리 삭제

적용 대상:SQL Server

CREATE ASSEMBLY 문을 사용하여 SQL Server에 등록된 어셈블리는 제공하는 기능이 더 이상 필요하지 않은 경우 삭제하거나 삭제할 수 있습니다. 어셈블리를 삭제하면 데이터베이스에서 어셈블리와 관련된 모든 파일(예: 디버그 파일)이 제거됩니다. 어셈블리를 삭제하려면 다음 구문과 함께 DROP ASSEMBLY 문을 사용합니다.

DROP ASSEMBLY MyDotNETAssembly;

DROP ASSEMBLY 현재 실행 중인 어셈블리를 참조하는 코드를 방해하지 않지만 DROP ASSEMBLY 실행되면 어셈블리 코드를 호출하려는 시도가 실패합니다.

DROP ASSEMBLY 데이터베이스에 있는 다른 어셈블리에서 어셈블리를 참조하거나 CLR(공용 언어 런타임) 함수, 프로시저, 트리거, UDT(사용자 정의 형식) 또는 현재 데이터베이스의 UDA(사용자 정의 집계)에서 사용되는 경우 오류를 반환합니다. 먼저 DROP AGGREGATE, DROP FUNCTION, DROP PROCEDURE, DROP TRIGGERDROP TYPE 문을 사용하여 어셈블리에 포함된 관리되는 데이터베이스 개체를 삭제합니다.

데이터베이스에서 UDT 제거

DROP TYPE 문은 현재 데이터베이스에서 UDT를 제거합니다. UDT가 삭제되면 DROP ASSEMBLY 문을 사용하여 데이터베이스에서 어셈블리를 삭제할 수 있습니다.

다음과 같은 경우와 같이 개체가 UDT에 의존하는 경우 DROP TYPE 문이 실패합니다.

  • UDT를 사용하여 정의한 열이 포함된 데이터베이스의 테이블

  • WITH SCHEMABINDING 절을 사용하여 데이터베이스에서 만든 UDT의 변수 또는 매개 변수를 사용하는 함수, 저장 프로시저 또는 트리거입니다.

UDT 종속성 찾기

먼저 모든 종속 개체를 삭제한 다음 DROP TYPE 문을 실행해야 합니다. 다음 Transact-SQL 쿼리는 AdventureWorks2022 데이터베이스에서 UDT를 사용하는 모든 열과 매개 변수를 찾습니다.

USE Adventureworks2022;
GO

SELECT o.name AS major_name,
       o.type_desc AS major_type_desc,
       c.name AS minor_name,
       c.type_desc AS minor_type_desc,
       at.assembly_class
FROM (SELECT object_id,
             name,
             user_type_id,
             'SQL_COLUMN' AS type_desc
      FROM sys.columns
      UNION ALL
      SELECT object_id,
             name,
             user_type_id,
             'SQL_PROCEDURE_PARAMETER'
      FROM sys.parameters) AS c
     INNER JOIN sys.objects AS o
         ON o.object_id = c.object_id
     INNER JOIN sys.assembly_types AS at
         ON at.user_type_id = c.user_type_id;