Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

SQL Server:Jak wywołać funkcję zdefiniowaną przez użytkownika (UDF) na serwerze połączonym?

Aby wywołać procedury zdalne, musisz aktywować RPC OUT na swoim połączonym serwerze. Otwórz Właściwości połączonego serwera w SSMS, a następnie kliknij „Opcje serwera” i upewnij się, że RPC Out jest True.

I...Twój link ma rozwiązanie Twojego problemu. Spójrz na ostatnią opcję w obejściu

Oto przypadek testowy dla Ciebie:

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'


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Pokaż zaawansowane opcje konfiguracji serwera w SQL Server (T-SQL)

  2. Dodawanie tożsamości do istniejącej kolumny

  3. SQL:Wybierz najnowszą wartość sekwencyjnie odmienną z grupowaniem

  4. Jak zoptymalizować SQL 'XQuery'

  5. Demistyfikacja typów oczekiwania CXPACKET i CXCONSUMER w SQL Server