我想从Azure SQL数据库查询本地SQL Server。 This回答似乎表明我可以通过“弹性数据库查询”功能来做到这一点。
但是,我读到的有关“弹性数据库查询”的所有内容仅提及连接到另一个 Azure SQL数据库,而不是本地SQL Server数据库。
我尝试通过一个接一个地运行这些语句来使用“弹性数据库查询”功能:
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'MY_SUPER_SECRET_PASSWORD';
CREATE DATABASE SCOPED CREDENTIAL SSDB_On_Premises_Credentials
WITH IDENTITY = 'MY_USERNAME',
SECRET = 'MY_OTHER_SUPER_SECRET_PASSWORD';
CREATE EXTERNAL DATA SOURCE SSDB_On_Premises WITH
(TYPE = RDBMS,
LOCATION = 'the.path.to.my.on.premises.database',
DATABASE_NAME = 'MyDatabaseName',
CREDENTIAL = SSDB_On_Premises_Credentials
) ;
CREATE EXTERNAL TABLE USER(
ID INT NOT NULL,
FIRSTNAME NVarchar(255),
LASTNAME NVarchar(255) NOT NULL
)
WITH
(
DATA_SOURCE = SSDB_On_Premises
);
SELECT * FROM USER;
然而,我收到此错误:
发生与网络相关或特定于实例的错误 建立与SQL Server的连接。找不到服务器或 无法访问。验证实例名称是否正确 SQL Server配置为允许远程连接。 (提供者:命名 管道提供程序,错误:40 - 无法打开与SQL的连接 服务器)
这可能是我的本地SQL Server上的配置设置有问题,但我猜测“弹性数据库查询”更有可能不会连接到本地数据源。
答案 0 :(得分:1)
没有。 CREATE EXTERNAL DATA SOURCE的文档指定目标必须是RDBMS外部数据源的Azure SQL数据库:
-- Elastic Database query only: a remote database on Azure SQL Database as data source
-- (only on Azure SQL Database)
CREATE EXTERNAL DATA SOURCE data_source_name
WITH (
TYPE = RDBMS,
LOCATION = '<server_name>.database.windows.net',
DATABASE_NAME = '<Remote_Database_Name>',
CREDENTIAL = <SQL_Credential>
)
[;]
新的(预览)Azure SQL数据库托管实例支持与SQL Server的链接服务器连接:
链接服务器
托管实例中的链接服务器支持有限 目标数量:支持的目标:SQL Server和SQL数据库不 支持的目标:文件,Analysis Services和其他RDBMS。
Azure SQL Database Managed Instance T-SQL differences from SQL Serve
Managed Instance也支持在私有VNet上运行,从中可以合理地连接到pre-premesis SQL Server实例。 Azure SQL数据库无法与您的on-premesis服务器通信。
答案 1 :(得分:1)
弹性数据库查询在Azure SQL数据库之间工作,并仅查询Azure SQL数据仓库。从架构的角度来看,如果弹性查询允许创建外部数据源到本地SQL Server实例,那么Azure将依赖其基础架构之外的服务器来满足查询。更好的体系结构可能是使用SQL Data Sync将本地数据库复制到Azure SQL上的中心数据库,然后使用该中心数据库创建弹性查询。即使从性能的角度来看也更有意义,因为查询不会针对您的本地数据库执行,并且延迟将不那么重要。