내보내기(0) 인쇄
모두 확장

USE FEDERATION(Azure SQL 데이터베이스)

업데이트 날짜: 2014년 4월

이 항목은 더 이상 사용되지 않습니다. SQL 14 Transact-SQL 참조(영문)에서 최신 버전을 찾을 수 있습니다. USE FEDERATION을 참조하십시오.

Important중요
현재 페더레이션 구현은 Web 및 Business와 함께 사용이 중지될 예정입니다. 확장성, 유동성 및 성능을 최대화하려면 사용자 지정 분할 솔루션을 배포하는 것이 좋습니다. 사용자 지정 분할에 대한 자세한 내용은 Azure SQL 데이터베이스 확장을 참조하십시오.

페더레이션에 연결합니다.

구문 표기 규칙(Azure SQL 데이터베이스)

USE FEDERATION ROOT
    WITH RESET


USE FEDERATION federation_name (distribution_name = value)
    WITH [FILTERING={ON|OFF},] RESET
[;]

ROOT
페더레이션 루트로 기존 연결을 설정합니다. 페더레이션 멤버에 연결된 경우 연결이 페더레이션 루트 데이터베이스로 다시 설정됩니다. 다른 데이터베이스에 연결된 경우에는 아무 효과가 없습니다.

federation_name
연결의 대상인 페더레이션의 이름입니다.

distribution_name
이 페더레이션에 대한 페더레이션 키의 이름입니다.

value
페더레이션 멤버에 연결하는 데 사용할 값입니다. 페더레이션 값을 제공하는 페더레이션 멤버가 연결이 설정되는 페더레이션 멤버가 됩니다.

이 값은 federation_name에 지정된 페더레이션이 정의한 형식을 따라야 합니다.

이 값은 NULL일 수 없습니다.

WITH FILTERING=ON|OFF
이 인수가 표시되지 않으면 FILTERING이 ON으로 설정됩니다.

FILTERING이 OFF로 설정되면 연결 범위가 지정된 키 값을 포함하는 페더레이션 멤버가 담당하는 전체 범위로 설정됩니다. 실제 페더레이션 멤버 이름(데이터베이스 이름)을 통해 멤버에 연결된 것과 동일하게 연결이 작동합니다.

전체 범위를 스캔하는 경우와 같이 응용 프로그램에서 페더레이션 멤버의 모든 데이터로 작업하려고 하고 응용 프로그램 내의 단일 원자성 페더레이션 원자성 단위 인스턴스에 필터링을 처리하는 논리를 이미 구현했을 때 FILTERING이 OFF로 설정됩니다.

FILTERING이 ON으로 설정되면 연결 범위가 페더레이션 멤버의 전체 범위가 아니라 페더레이션 멤버의 페더레이션 키 인스턴스로 설정됩니다. 이 모드에서는 쿼리 프로세서가 페더레이션 열에 대한 조건자(fed_column=value)를 페더레이션된 테이블을 참조하는 모든 쿼리에 추가합니다.

응용 프로그램에서 원자성 페더레이션 원자성 단위(예: tenant_id 55)로 액세스를 자동으로 한정하려는 경우 FILTERING이 ON으로 설정됩니다.

WITH RESET
연결을 명시적으로 다시 설정하게 하는 필수 키워드입니다.

USE FEDERATION 문은 응용 프로그램에서 먼저 페더레이션 개체를 포함하는 데이터베이스에 연결하고 USE FEDERATION 문을 통해 특정 페더레이션 멤버로 전환할 수 있도록 하여 기존 연결 라이브러리에 대한 효율적인 연결 풀링 동작을 제공합니다. 이에 따라 클라이언트 연결 풀이 개별 페더레이션 멤버 또는 페더레이션 원자성 단위 값을 처리해야 하는 경우보다 작아집니다.

USE FEDERATION은 연결 수명의 어느 시점에서든 연결에 대해 실행될 수 있지만 일괄 처리에서는 유일한 문이어야 하고 매개 변수화를 지원하지 않습니다.

USE FEDERATION은 현재 페더레이션 멤버 또는 루트 데이터베이스에서 페더레이션 루트 또는 페더레이션 멤버에 포함된 지정된 값으로 연결을 다시 구성합니다. USE FEDERATION을 통해 연결이 다시 구성되면 연결이 다시 설정됩니다. 따라서 기존 설정과 연결의 컨텍스트가 모두 손실됩니다. 이는 연결이 연결 풀에서 검색될 때 sp_reset_connection을 실행하는 것과 동일합니다.

master 데이터베이스에는 페더레이션이 포함될 수 없으므로 master 데이터베이스 내에서 실행된 USE FEDERATION ROOT는 아무 효과가 없습니다.

존재하지 않는 페더레이션 이름을 사용하는 USE FEDERATION은 '페더레이션 <federation name>이(가) 없습니다.'와 같은 오류를 반환합니다.

FILTERING=ON을 사용하면 지정된 페더레이션 키 인스턴스로만 연결의 뷰를 제한할 수 있습니다. 페더레이션 키 인스턴스에 연결하면 특정 페더레이션 원자성 단위에 쿼리가 바인딩됩니다. 이에 따라 조건자 P를 도입하여 연결에 대해 실행되는 쿼리의 의미 체계가 수정됩니다. P는 지정된 쿼리의 페더레이션된 모든 테이블에 대해 Federation_Column =@filtering_value로 주입됩니다.

현재 페더레이션 필터링 값에서 행을 이동하거나, 삽입 또는 로드하려는 모든 쿼리는 올바르지 않으며 P를 적용하는 대상 테이블에 CHECK 제약 조건이 있는 것처럼 실패합니다.

Warning경고
페더레이션 원자성 단위는 명시적으로 보안 경계가 아닙니다. 쿼리 프로세서는 단위 간에 정보가 누출되지 않도록 보장하지 않습니다. 범위 외부의 행이 부분적으로 처리될 수도 있습니다. 임의의 스칼라 논리가 이러한 행에 대해 실행될 수 있으며, 이에 따라 오버플로 또는 0으로 나누기 등의 예기치 않은 예외가 발생할 수 있습니다.

다음 예에서는 페더레이션 루트에 대한 연결을 라우팅하는 방법을 보여 줍니다.

using (SqlConnection connection = new SqlConnection(connectionString)) 
{ 
    connection.Open(); 
 
    using (SqlCommand command = connection.CreateCommand()) 
    { 
        // Route the connection to federation root 
        // Note that the CommandText should not contain any additional commends
        command.CommandText = "USE FEDERATION ROOT WITH RESET"; 
        command.ExecuteNonQuery(); 
    } 
}

표시:
© 2014 Microsoft