我不知道如何配置OpenQuery
功能。
我想使用OpenQuery
来查询测试项目中的数据库。但我不知道如何配置servername param
DECLARE @Sql varchar(max)
DECLARE @SQLExcuteSentence varchar(max)
SET @Sql = 'declare @UserID INT
select @UserID = 1
declare @TotalGroupByFields nvarchar(2000)
select @TotalGroupByFields = ''Media''
declare @CostDataFileds nvarchar(2000)
select @CostDataFileds = ''''
declare @OtherDataFields nvarchar(max)
select @OtherDataFields = ''MonitoringSpotNumber,MonitoringTotalSeconds,BaseCost,ColourLoading,PositionLoading,WeekendLoading,Discount''
declare @MasterFilterId nvarchar(max)
select @MasterFilterId =''DateRange=20060601-20121231''+char(13)+''IncludeGuests=0''
declare @RatingTargetId nvarchar(2000)
select @RatingTargetId =''''
declare @IsEnableFinancialCloseDate INT
select @IsEnableFinancialCloseDate = 0
declare @MasterDisplayFormat nvarchar(2000)
select @MasterDisplayFormat = ''5''
exec [dbo].[USP_MatrixReport] @UserID, @TotalGroupByFields, @CostDataFileds, @OtherDataFields, @MasterFilterId, @RatingTargetId, @IsEnableFinancialCloseDate, @MasterDisplayFormat, 0'
SET @SQLExcuteSentence = 'SELECT * FROM OPENQUERY(SQLConn,' + '''' + @Sql + '''' + ')'
EXEC (@SQLExcuteSentence);
SQLConn是什么?
答案 0 :(得分:2)
OPENQUERY要求您首先使用sp_addlinkedserver设置链接服务器。这就是设置连接字符串的地方。
之后,您可以使用OPENQUERY
针对链接服务器触发查询。
答案 1 :(得分:1)
如果没有SQL Server Management Studio,对于localhost,它看起来像这样:
EXEC sp_addlinkedserver
@server='LOCALSERVER', -- name definition for later use in OpenQuery
@srvproduct='SQLSERVER',
@provider='SQLNCLI', -- provider name
@datasrc='SERVERNAME\INSTANCENAME' -- im not sure if there should be '\' or not
excel文件的其他示例(基于Manoj代码):
EXEC sp_addLinkedServer
@server= N'XLSX_2010',
@srvproduct = N'Excel',
@provider = N'Microsoft.ACE.OLEDB.12.0',
@datasrc = N'C:\Users\SomeUser\Desktop\file.xlsx',
@provstr = N'Excel 12.0; HDR=Yes';
使用SQL Server Management Studio且没有的localhost示例: