교차 데이터베이스 쿼리: 서버 링크 및 OPENQUERY 사용
다른 데이터베이스의 데이터에 액세스하는 방법에는 여러 가지가 있으며 그 중 하나는 서버 링크와 OPENQUERY를 사용하는 것입니다.
서버링크
다른 서버의 데이터베이스를 연결하려면 저장 프로시저sp_addlinkedserver
를 사용하여 서버 링크를 생성할 수 있습니다. 이를 통해 연결된 서버의 테이블에 액세스하고 쿼리를 실행할 수 있습니다. 다른 데이터베이스의 테이블을 조인하려면 테이블 이름 앞에 연결된 서버 이름을 추가하면 됩니다. 예:
<code class="language-sql">SELECT * FROM [LinkedServerName].[DatabaseName].[SchemaName].[TableName]</code>
OPENQUERY
또는 OPENQUERY를 사용하면 서버에 영구적으로 연결하지 않고도 원격으로 SQL 문을 실행하고 데이터를 검색할 수 있습니다. 구문은 다음과 같습니다.
<code class="language-sql">SELECT * FROM OPENQUERY([LinkedServerName], 'SELECT * FROM [DatabaseName].[SchemaName].[TableName]')</code>
OPENQUERY는 원격 서버가 쿼리 실행을 최적화할 수 있도록 하여 성능을 향상시킵니다. 또한 후속 쿼리를 위해 결과를 임시 테이블로 캐시할 수 있습니다.
예
서버 링크와 OPENQUERY의 사용을 설명하기 위해 서로 다른 서버의 서로 다른 데이터베이스에 있는 두 테이블을 조인하는 시나리오를 생각해 보세요.
서버 연동 방식 :
<code class="language-sql">SELECT * FROM [Database1].[dbo].[Table1] t1 INNER JOIN [LinkedServerName].[Database2].[dbo].[Table2] t2 ON t1.ID = t2.ID</code>
OPENQUERY 방법:
<code class="language-sql">-- 从远程数据库获取数据 SELECT * INTO #TempTable FROM OPENQUERY([LinkedServerName], 'SELECT * FROM [Database2].[dbo].[Table2]') -- 将临时表与本地表连接 SELECT * FROM [Database1].[dbo].[Table1] t1 INNER JOIN #TempTable t2 ON t1.ID = t2.ID</code>
이 두 가지 방법 중 선택은 데이터 크기, 쿼리 복잡성, 성능 요구 사항 등의 요소에 따라 달라집니다.
위 내용은 서버 링크와 OPENQUERY가 데이터베이스 간 쿼리를 어떻게 촉진할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!