ALTER ASSEMBLY(Transact-SQL)
어셈블리의 SQL Server 카탈로그 속성을 수정하여 어셈블리를 변경합니다. ALTER ASSEMBLY는 어셈블리의 구현을 유지하는 Microsoft.NET Framework 모듈의 최신 복사본으로 어셈블리를 새로 고치고 어셈블리와 연관된 파일을 추가하거나 제거합니다. 어셈블리는 CREATE ASSEMBLY를 사용하여 만듭니다.
구문
ALTER ASSEMBLY assembly_name
[ FROM <client_assembly_specifier> | <assembly_bits> ]
[ WITH <assembly_option> [ ,...n ] ]
[ DROP FILE { file_name [ ,...n ] | ALL } ]
[ ADD FILE FROM
{
client_file_specifier [ AS file_name ]
| file_bits AS file_name
} [,...n ]
] [ ; ]
<client_assembly_specifier> :: =
'\\computer_name\share-name\[path\]manifest_file_name'
| '[local_path\]manifest_file_name'
<assembly_bits> :: =
{ varbinary_literal | varbinary_expression }
<assembly_option> :: =
PERMISSION_SET = { SAFE | EXTERNAL_ACCESS | UNSAFE }
| VISIBILITY = { ON | OFF } ]
| UNCHECKED DATA
인수
assembly_name
수정하려는 어셈블리의 이름입니다. assembly_name은 데이터베이스에 이미 있어야 합니다.FROM <client_assembly_specifier> | <assembly_bits>
어셈블리의 구현을 유지하는 .NET Framework 모듈의 최신 복사본으로 어셈블리를 업데이트합니다. 지정한 어셈블리와 관련된 파일이 없는 경우에만 이 옵션을 사용할 수 있습니다.<client_assembly_specifier>는 새로 고칠 어셈블리가 있는 네트워크 위치나 로컬 위치를 지정합니다. 네트워크 위치에는 컴퓨터 이름, 공유 이름 및 해당 공유 내의 경로가 포함됩니다. manifest_file_name 은 어셈블리의 매니페스트가 들어 있는 파일의 이름을 지정합니다.
<assembly_bits>는 어셈블리에 대한 이진 값입니다.
업데이트도 필요한 모든 종속 어셈블리에 대해 별도의 ALTER ASSEMBLY 문을 실행해야 합니다.
PERMISSION_SET = { SAFE | EXTERNAL_ACCESS | UNSAFE }
어셈블리의 .NET Framework 코드 액세스 권한 설정 속성을 지정합니다. 이 속성에 대한 자세한 내용은 CREATE ASSEMBLY(Transact-SQL)를 참조하십시오.VISIBILITY = { ON | OFF }
어셈블리에 대해 CLR(공용 언어 런타임) 함수, 저장 프로시저, 트리거, 사용자 정의 형식 및 사용자 정의 집계 함수를 만들 때 어셈블리를 표시할지 여부를 나타냅니다. 이 인수가 OFF로 설정되어 있으면 어셈블리가 다른 어셈블리에서 호출되는 용도로만 사용됩니다. 어셈블리에 대해 생성된 기존 CLR 데이터베이스가 있는 경우 어셈블리의 표시 유형을 변경할 수 없습니다. assembly_name으로 참조되는 모든 어셈블리는 기본적으로 표시되지 않는 상태로 업로드됩니다.UNCHECKED DATA
기본적으로 개별 테이블 행의 일관성을 확인해야 하는 경우 ALTER ASSEMBLY가 실패합니다. 이 옵션을 사용하면 나중에 DBCC CHECKTABLE을 사용할 때까지 일관성 확인을 연기할 수 있습니다. 이 옵션을 지정하면 SQL Server는 데이터베이스에 다음을 포함하는 테이블이 있는 경우에도 ALTER ASSEMBLY 문을 실행합니다.Transact-SQL 함수나 메서드를 통해 직접 또는 간접적으로 어셈블리의 메서드를 참조하는 지속형 계산 열
직접 또는 간접적으로 어셈블리의 메서드를 참조하는 CHECK 제약 조건
어셈블리에 종속된 CLR 사용자 정의 형식의 열. 이 유형은 UserDefined(비네이티브) 직렬화 형식을 구현해야 합니다.
WITH SCHEMABINDING을 사용하여 생성된 뷰를 참조하는 CLR 사용자 정의 형식의 열
CHECK 제약 조건이 있는 경우 비활성화되며 신뢰할 수 없는 상태로 표시됩니다. 어셈블리에 의존하는 열이 포함된 모든 테이블은 명시적으로 확인되기 전까지 확인되지 않은 데이터를 포함하는 것으로 표시됩니다.
db_owner 및 db_ddlowner 고정 데이터베이스 역할의 멤버만이 이 옵션을 지정할 수 있습니다.
자세한 내용은 어셈블리 구현을 참조하십시오.
[ DROP FILE { file_name[ ,...n] | ALL } ]
어셈블리와 관련된 특정 파일이나 모든 파일을 데이터베이스에서 제거합니다. ADD FILE이 뒤따를 경우 DROP FILE이 먼저 실행됩니다. 이 기능을 사용하여 같은 파일 이름의 파일을 대체할 수 있습니다.[ ADD FILE FROM { client_file_specifier [ AS file_name] | file_bitsAS file_name}
소스 코드, 디버그 파일 또는 기타 관련 정보와 같은 어셈블리와 관련된 파일을 서버로 업로드하고 sys.assembly_files 카탈로그 뷰에 표시합니다. client_file_specifier는 업로드할 파일이 있는 위치를 지정합니다. 이 옵션 대신 file_bits를 사용하면 파일을 구성하는 이진 값 목록을 지정할 수 있습니다. file_name은 SQL Server 인스턴스에 저장되어야 하는 파일 이름을 지정합니다. file_name은 file_bits를 지정한 경우에는 반드시 지정해야 하고 client_file_specifier를 지정한 경우에는 선택 사항입니다. file_name을 지정하지 않으면 client_file_specifier의 file_name 부분이 file_name으로 사용됩니다.
주의
ALTER ASSEMBLY는 현재 실행 중인 세션(수정 중인 어셈블리에서 실행 중인 코드)을 방해하지 않습니다. 현재 세션은 어셈블리의 변경되지 않은 비트를 사용하여 실행이 완료됩니다.
FROM 절이 지정되면 ALTER ASSEMBLY는 제공된 모듈의 최신 복사본을 기준으로 어셈블리를 업데이트합니다. SQL Server의 인스턴스에 어셈블리에 대해 정의된 CLR 함수, 저장 프로시저, 트리거, 데이터 형식 및 사용자 정의 집계 함수가 있을 수 있으므로 ALTER ASSEMBLY 문은 이러한 항목을 어셈블리의 최신 구현에 다시 바인딩합니다. 이렇게 다시 바인딩하기 위해서는 동일한 서명의 수정된 어셈블리에도 CLR 함수, 저장 프로시저 및 트리거를 매핑하는 메서드가 있어야 합니다. CLR 사용자 정의 형식 및 사용자 정의 집계 함수를 구현하는 클래스는 여전히 사용자 정의 형식이나 집계에 대한 요구 사항을 충족해야 합니다.
주의 |
---|
WITH UNCHECKED DATA를 지정하지 않으면 새 어셈블리 버전이 테이블, 인덱스 또는 다른 영구 사이트의 기존 데이터에 영향을 주는 경우 SQL Server에서 ALTER ASSEMBLY를 실행하지 못하도록 합니다. 그러나 SQL Server에서 CLR 어셈블리를 업데이트할 때 계산 열, 인덱스, 인덱싱된 뷰 또는 식이 기본 루틴 및 유형과 일치하도록 보장하지는 않습니다. ALTER ASSEMBLY를 실행하여 어셈블리에 저장된 해당 식을 기반으로 하는 식 결과와 값이 일치하는지 확인하는 경우 주의하십시오. |
ALTER ASSEMBLY는 어셈블리 버전을 변경합니다. 어셈블리의 culture 및 공개 키 토큰은 동일하게 유지됩니다.
다음을 변경하는 데 ALTER ASSEMBLY 문을 사용할 수 없습니다.
어셈블리를 참조하는 SQL Server 인스턴스의 CLR 함수, 집계 함수, 저장 프로시저 및 트리거의 서명. SQL Server에서 어셈블리의 새 버전으로 SQL Server의 .NET Framework 데이터베이스 개체를 다시 바인딩할 수 없는 경우 ALTER ASSEMBLY가 실패합니다.
다른 어셈블리에서 호출되는 어셈블리에 있는 메서드의 서명
어셈블리의 DependentList 속성으로 참조되는 어셈블리에 종속된 어셈블리 목록
해당 메서드에 직접 또는 간접적으로 의존하는 인덱스나 지속형 계산 열이 없는 경우 메서드의 인덱싱 가능성
CLR 테이블 반환 함수의 FillRow 메서드 이름 특성
사용자 정의 집계의 Accumulate 및 Terminate 메서드 서명
시스템 어셈블리
어셈블리 소유권. 대신 ALTER AUTHORIZATION(Transact-SQL)을 사용하십시오.
또한 사용자 정의 형식을 구현하는 어셈블리에 대해 다음 변경을 수행하는 경우에만 ALTER ASSEMBLY를 사용할 수 있습니다.
서명 또는 특성이 변경되지 않는 경우 사용자 정의 형식 클래스의 공용 메서드를 수정하는 경우
새 공용 메서드를 추가하는 경우
전용 메서드를 어떤 방식으로든 수정하는 경우
데이터 멤버 또는 기본 클래스를 비롯하여 기본적으로 직렬화된 사용자 정의 형식에 포함된 필드는 ALTER ASSEMBLY를 사용하여 변경할 수 없습니다. 다른 모든 변경은 지원되지 않습니다.
ADD FILE FROM을 지정하지 않을 경우 ALTER ASSEMBLY는 어셈블리와 관련된 모든 파일을 삭제합니다.
UNCHECKED 데이터 절 없이 ALTER ASSEMBLY를 실행하면 새 어셈블리 버전이 테이블의 기존 데이터에 영향을 미치지 않는지 확인하는 검사가 수행됩니다. 확인해야 하는 데이터 양에 따라 이 검사가 성능에 영향을 미칠 수 있습니다.
사용 권한
어셈블리에 대한 ALTER 권한이 필요합니다. 추가 요구 사항은 다음과 같습니다.
기존 권한이 EXTERNAL_ACCESS로 설정되어 있는 어셈블리를 변경하려면 SQL Server 로그인에 서버에 대한 EXTERNAL ACCESS 권한이 있어야 합니다.
기존 권한이 UNSAFE로 설정되어 있는 어셈블리를 변경하려면 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다.
어셈블리의 사용 권한 설정을 EXTERNAL_ACCESS로 변경하려면 SQL Server 로그인에 서버에 대한 EXTERNAL ACCESS ASSEMBLY 권한이 있어야 합니다.
어셈블리의 사용 권한 설정을 UNSAFE로 변경하려면 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다.
WITH UNCHECKED DATA를 지정하려면 sysadmin 고정 서버 역할의 멤버 자격이 필요합니다.
어셈블리 사용 권한 설정에 대한 자세한 내용은 어셈블리 디자인을 참조하십시오.
예
1. 어셈블리 새로 고치기
다음 예에서는 ComplexNumber 어셈블리를 어셈블리의 구현을 유지하는 .NET Framework 모듈의 최신 복사본으로 업데이트합니다.
[!참고]
ComplexNumber 어셈블리는 UserDefinedDataType 예제 스크립트를 실행하여 만들 수 있습니다. 자세한 내용은 User-Defined Type (UDT) Sample를 참조하십시오.
ALTER ASSEMBLY ComplexNumber
FROM 'C:\Program Files\Microsoft SQL Server\90\Tools\Samples\1033\Engine\Programmability\CLR\UserDefinedDataType\CS\ComplexNumber\obj\Debug\ComplexNumber.dll'
2. 어셈블리와 연결할 파일 추가
다음 예에서는 MyClass 어셈블리와 연결할 소스 코드 파일 Class1.cs를 업로드합니다. 이 예에서는 데이터베이스에 이미 MyClass 어셈블리가 있다고 가정합니다.
ALTER ASSEMBLY MyClass
ADD FILE FROM 'C:\MyClassProject\Class1.cs';
3. 어셈블리의 사용 권한 변경
다음 예에서는 ComplexNumber 어셈블리 사용 권한 설정을 SAFE에서 EXTERNAL ACCESS로 변경합니다.
ALTER ASSEMBLY ComplexNumber WITH PERMISSION_SET = EXTERNAL_ACCESS