>데이터 베이스 >MySQL 튜토리얼 >서버 링크와 OPENQUERY가 데이터베이스 간 쿼리를 어떻게 촉진할 수 있습니까?

서버 링크와 OPENQUERY가 데이터베이스 간 쿼리를 어떻게 촉진할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-13 10:24:44888검색

How Can Server Links and OPENQUERY Facilitate Cross-Database Queries?

교차 데이터베이스 쿼리: 서버 링크 및 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.