ALTER JOIN POLICY¶
조인 정책 에 대한 기존 규칙 또는 설명을 바꿉니다. 또한 조인 정책의 이름을 변경할 수 있습니다.
- 참고 항목:
구문¶
ALTER JOIN POLICY [ IF EXISTS ] <name> RENAME TO <new_name>
ALTER JOIN POLICY [ IF EXISTS ] <name> SET BODY -> <expression>
ALTER JOIN POLICY <name> SET TAG <tag_name> = '<tag_value>' [ , <tag_name> = '<tag_value>' ... ]
ALTER JOIN POLICY <name> UNSET TAG <tag_name> [ , <tag_name> ... ]
ALTER JOIN POLICY [ IF EXISTS ] <name> SET COMMENT = '<string_literal>'
ALTER JOIN POLICY [ IF EXISTS ] <name> UNSET COMMENT
매개 변수¶
name
변경할 조인 정책의 식별자를 지정합니다.
식별자에 공백이나 특수 문자가 포함된 경우 전체 문자열을 큰따옴표로 묶어야 합니다. 큰따옴표로 묶인 식별자도 대/소문자를 구분합니다.
자세한 내용은 식별자 요구 사항 섹션을 참조하십시오.
RENAME TO new_name
조인 정책에 대한 새 식별자를 지정합니다. 조인 정책은 스키마에 대해 고유해야 합니다. 다른 조인 정책에 이미 식별자가 있는 경우에는 새 식별자를 사용할 수 없습니다.
자세한 내용은 식별자 요구 사항 섹션을 참조하십시오.
선택적으로 오브젝트의 이름을 바꾸는 동안 오브젝트를 다른 데이터베이스 및/또는 스키마로 이동할 수 있습니다. 그러려면 각각
db_name.schema_name.object_name
또는schema_name.object_name
형식으로 새 데이터베이스 및/또는 스키마 이름을 포함하는 정규화된new_name
값을 지정하십시오.참고
대상 데이터베이스 및/또는 스키마가 이미 있어야 합니다. 또한, 새 위치에 이름이 같은 오브젝트가 있으면 안 됩니다. 그렇지 않으면 문이 오류를 반환합니다.
오브젝트 소유자(즉, 오브젝트에 대한 OWNERSHIP 권한이 있는 역할) 역시 대상 스키마를 소유하지 않는 한 오브젝트를 관리되는 액세스 스키마로 이동하는 것은 금지됩니다.
SET ...
조인 정책에 대해 설정할 속성을 1개(또는 여러 개)를 지정합니다.
BODY -> expression
SQL 식을 사용하여 조인 정책의 제한을 결정합니다.
조인 정책의 본문을 정의하려면 TRUE 또는 FALSE 를 반환하는 JOIN_CONSTRAINT 함수를 호출합니다. 함수가 TRUE 를 반환하는 경우 쿼리 결과를 반환하려면 조인을 사용해야 합니다.
JOIN_CONSTRAINT 함수의 구문은 다음과 같습니다.
JOIN_CONSTRAINT ( { JOIN_REQUIRED => <boolean_expression> } )
여기서
JOIN_REQUIRED => boolean_expression
조인 정책이 할당된 테이블 또는 뷰에서 데이터를 선택할 때 쿼리에서 조인이 요구되는지 여부를 지정합니다.
정책 본문은 사용자 정의 함수, 테이블 또는 뷰를 참조할 수 없습니다.
허용되는 조인 열은 정책이 적용되는 테이블 또는 뷰의 CREATE 또는 ALTER 문에 지정되며 CREATE JOIN POLICY 문에는 지정되지 않습니다.
TAG tag_name = 'tag_value' [ , tag_name = 'tag_value' , ... ]
태그 이름과 태그 문자열 값을 지정합니다.
태그 값은 항상 문자열이며, 태그 값의 최대 문자 수는 256자입니다.
문에서 태그를 지정하는 방법에 대한 자세한 내용은 오브젝트 및 열에 대한 태그 할당량 섹션을 참조하십시오.
COMMENT = 'string_literal'
설명을 추가하거나 조인 정책에 대한 기존 설명을 덮어씁니다.
기본값: 값 없음
UNSET ...
조인 정책에 대해 기본값으로 재설정하여 설정 해제할 1개 이상의 속성 및/또는 매개 변수를 지정합니다.
TAG tag_name [ , tag_name ... ]
COMMENT
속성/매개 변수를 재설정할 때는 이름만 지정하십시오. 속성 값을 지정하면 오류가 반환됩니다.
액세스 제어 요구 사항¶
이 작업을 실행하는 데 사용되는 역할 에는 최소한 다음 권한 이 있어야 합니다.
권한 |
오브젝트 |
참고 |
---|---|---|
OWNERSHIP |
조인 정책 |
OWNERSHIP is a special privilege on an object that is automatically granted to the role that created the object, but can also be transferred using the GRANT OWNERSHIP command to a different role by the owning role (or any role with the MANAGE GRANTS privilege). |
스키마의 모든 오브젝트에 대해 작업을 수행하려면 상위 데이터베이스 및 스키마에 대한 USAGE 권한.
지정된 권한 세트로 사용자 지정 역할을 만드는 방법에 대한 지침은 사용자 지정 역할 만들기 섹션을 참조하십시오.
보안 오브젝트 에 대해 SQL 작업을 수행하기 위한 역할과 권한 부여에 대한 일반적인 정보는 액세스 제어의 개요 섹션을 참조하십시오.
조인 정책 DDL 및 권한에 대한 자세한 내용은 권한과 명령 섹션을 참조하십시오.
사용법 노트¶
기존 조인 정책을 업데이트하고 정책의 현재 본문을 확인해야 하는 경우 DESCRIBE JOIN POLICY 명령을 실행하십시오. GET_DDL 함수를 사용하여 본문을 포함한 조인 정책의 전체 정의를 가져올 수도 있습니다.
조인 정책 소유자(즉, 조인 정책에 대한 OWNERSHIP 권한을 가진 역할) 역시 대상 스키마를 소유하지 않는 한 (ALTER JOIN POLICY … RENAME TO 구문을 사용하여) 조인 정책을 관리되는 액세스 스키마 로 이동하는 것은 금지됩니다.
메타데이터 관련:
주의
고객은 Snowflake 서비스를 사용할 때 개인 데이터(사용자 오브젝트 제외), 민감한 데이터, 수출 통제 대상 데이터 또는 기타 규제 데이터가 메타데이터로 입력되지 않도록 해야 합니다. 자세한 내용은 Snowflake의 메타데이터 필드 섹션을 참조하십시오.
예¶
조인 정책에 대한 SQL 식을 수정합니다.
ALTER JOIN POLICY jp3 SET BODY -> JOIN_CONSTRAINT(JOIN_REQUIRED => FALSE);
조인 정책의 이름을 바꿉니다.
ALTER JOIN POLICY my_join_policy RENAME TO my_join_policy_2;