Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

SQL Server :Comment appeler une fonction définie par l'utilisateur (UDF) sur un serveur lié ?

Pour appeler des procédures distantes, vous devez activer RPC OUT sur votre serveur lié. Ouvrez les propriétés du serveur lié dans SSMS, puis cliquez sur "Option de serveur" et assurez-vous que RPC Out est vrai.

Et...Votre lien a la solution à votre problème. Regardez la dernière option dans le WorkAround

Voici un cas de test pour vous :

use master
go
EXEC master.dbo.sp_addlinkedserver @server = N'(LOCAL)', @srvproduct=N'SQL Server';
EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'(LOCAL)',@useself=N'True',@locallogin=NULL,@rmtuser=NULL,@rmtpassword=NULL;
EXEC master.dbo.sp_serveroption @server=N'(LOCAL)', @optname=N'rpc out', @optvalue=N'true'
GO
Use Testing
GO
CREATE FUNCTION [dbo].[UserGroupMembershipNames](@UserGUID uniqueidentifier)  
RETURNS VARCHAR(8000)
AS
BEGIN
    RETURN 'hello'
END
GO
select dbo.[UserGroupMembershipNames]('4278E0BF-2F7A-4D60-A09C-95E517E21EBC')
GO
exec [(LOCAL)].Testing.dbo.sp_executesql 
N'select dbo.UserGroupMembershipNames(@UserGUID)',N'@UserGUID uniqueidentifier'
,@UserGUID='4278E0BF-2F7A-4D60-A09C-95E517E21EBC'