다음을 통해 공유


sp_replcmds(Transact-SQL)

적용 대상: SQL Server Azure SQL Managed Instance

복제로 표시된 트랜잭션에 대한 명령을 반환합니다. 이 저장 프로시저는 게시 데이터베이스의 게시자에서 실행됩니다.

Important

이 절차는 sp_replcmds 복제 문제를 해결하기 위해서만 실행해야 합니다.

Transact-SQL 구문 표기 규칙

구문

sp_replcmds [ @maxtrans = ] maxtrans
[ ; ]

인수

[ @maxtrans = ] maxtrans

정보를 반환할 트랜잭션 수입니다. @maxtrans 기본값1인 int이며 배포 대기 중인 다음 트랜잭션을 지정합니다.

결과 집합

열 이름 데이터 형식 설명
article id int 아티클의 ID입니다.
partial_command bit 이 명령이 부분 명령인지 여부를 나타냅니다.
command varbinary(1024) 명령 값입니다.
xactid binary(10) 트랜잭션 ID입니다.
xact_seqno varbinary(16) 트랜잭션 시퀀스 번호입니다.
publication_id int 게시의 ID입니다.
command_id int MSrepl_commands 명령의 ID입니다.
command_type int 명령 유형입니다.
originator_srvname sysname 트랜잭션이 시작된 서버입니다.
originator_db sysname 트랜잭션이 시작된 데이터베이스입니다.
pkHash int 내부용으로만 사용됩니다.
originator_publication_id int 트랜잭션이 시작된 게시의 ID입니다.
originator_db_version int 트랜잭션이 시작된 데이터베이스의 버전입니다.
originator_lsn varbinary(16) 원래 게시에서 명령에 대한 LSN(로그 시퀀스 번호)을 식별합니다.

설명

sp_replcmds 는 트랜잭션 복제의 로그 판독기 프로세스에서 사용됩니다.

복제는 지정된 데이터베이스 내에서 실행되는 sp_replcmds 첫 번째 클라이언트를 로그 판독기로 처리합니다.

이 프로시저는 소유자로 한정된 테이블에 대한 명령을 생성하거나 테이블 이름(기본값)을 한정하지 않을 수 있습니다. 정규화된 테이블 이름을 추가하면 한 데이터베이스의 특정 사용자가 소유한 테이블에서 다른 데이터베이스의 동일한 사용자가 소유한 테이블로 데이터를 복제할 수 있습니다.

원본 데이터베이스의 테이블 이름은 소유자 이름에 의해 한정되므로 대상 데이터베이스의 테이블 소유자는 반드시 같은 소유자 이름을 사용해야 합니다.

동일한 데이터베이스 내에서 실행 sp_replcmds 하려는 클라이언트는 첫 번째 클라이언트의 연결이 끊어지도록 오류 18752를 수신합니다. 첫 번째 클라이언트 연결이 끊어진 후 다른 클라이언트를 실행할 sp_replcmds수 있으며 새 로그 판독자가 됩니다.

텍스트 포인터가 동일한 트랜잭션에서 검색되지 않았기 때문에 텍스트 명령을 복제할 수 없는 경우 sp_replcmds SQL Server 오류 로그와 Microsoft Windows 애플리케이션 로그 모두에 경고 메시지 번호 18759가 추가됩니다.

사용 권한

sysadmin 고정 서버 역할 또는 db_owner 고정 데이터베이스 역할의 멤버만 실행할 sp_replcmds수 있습니다.