SqlServer 远程执行存储过程或其他非DML语句

 更新时间:2021年3月10日 17:11  点击:1257

SQL server 数据库调用远程数据库存储过程的实现方法

1、两台数据库 sql1和sql2


2、在sql1上创建存储过程,在sql2上设置定时任务执行存储过程


思路:


1、在sql1上创建job,执行存储过程;在sql2上创建job调用sql1上的job即可。


2、使用dblink去执行,参考:http://blog.csdn.net/kk185800961/article/details/48003293


实现:


1、在sql1上创建存储过程省略


2、在sql1上创建job,并能够使其执行


3、在sql2上创建job,在step界面增加新step,并添加如下语句: EXEC sp_serveroption 'sql1', 'rpc out', 'true'; GO EXECUTE ( ' EXEC MSDB.dbo.sp_start_job N''test_procedure'' ') AT [sql1]


这样既可实现此场景。


原本服务器有1个链接服务器,这是建立发布订阅时创建的,创建命令导出如下(都为同一域中的计算机):

EXEC master.dbo.sp_addlinkedserver
 @server = N'LinkServerName',
 @srvproduct=N'SQL Server' 
GO
 
EXEC master.dbo.sp_addlinkedsrvlogin
 @rmtsrvname=N'LinkServerName',
 @useself=N'True',
 @locallogin=NULL,
 @rmtuser=NULL,
 @rmtpassword=NULL
GO


该链接服务器可以进行远程查询,但是调用远程存储过程执行命令时出错:

EXEC [LinkServerName].[DB].DBO.SP_EXECUTESQL N'GRANT SELECT,INSERT,UPDATE,DELETE,REFERENCES ON [AAAAA] TO [username]'


消息 18483,级别 14,状态 1,第 1 行

由于没有在服务器 'LinkServerName' 上将 '' 定义为远程登录名,所以无法连接到该服务器。请确保指定的登录名正确无误。。


查看服务器信息:

SELECT name,product,provider,data_source,is_linked,is_remote_proc_transaction_promotion_enabled FROM sys.servers


 --@srvproduct=N'SQL Server'  无法远程执行,现在换一种接口类型。
 

EXEC master.dbo.sp_droplinkedsrvlogin [LinkServerName],Null 
EXEC master.dbo.sp_dropserver [LinkServerName]
GO
 
 
EXEC master.dbo.sp_addlinkedserver
 @server = N'LinkServerName',
 @srvproduct=N'',
 @provider='SQLNCLI',
 @datasrc='ServerName or IP'
GO
EXEC master.dbo.sp_addlinkedsrvlogin
 @rmtsrvname=N'LinkServerName',
 @useself=N'True',
 @locallogin=NULL,
 @rmtuser=NULL,
 @rmtpassword=NULL
GO


再执行远程存储过程,错误如下:


消息 7411,级别 16,状态 1,第 1 行

未将服务器 'DB03' 配置为用于 RPC。


开启 RPC 远程过程调用:

EXEC master.dbo.sp_serveroption @server=N'LinkServerName', @optname=N'rpc', @optvalue=N'true'
EXEC master.dbo.sp_serveroption @server=N'LinkServerName', @optname=N'rpc out', @optvalue=N'true'


不可在界面上启用RPC,否则报错:


不允许对系统目录进行即席更新。(Microsoft SQL Server , 错误:259)




好了,现在再执行:

EXEC [LinkServerName].[DB].DBO.SP_EXECUTESQL N'GRANT SELECT,INSERT,UPDATE,DELETE,REFERENCES ON [AAAAA] TO [username]'


命令执行成功!


附:几种远程查询

SELECT * FROM [LinkServerName].[DB].dbo.AAAAA
SELECT * FROM OPENQUERY([LinkServerName],'SELECT * FROM DB.dbo.AAAAA')
SELECT * FROM OPENDATASOURCE('SQLNCLI','Data Source=;Integrated Security=SSPI').DB.dbo.AAAAA
SELECT * FROM OPENROWSET('SQLNCLI','Server=ServerName;Trusted_Connection=yes;','SELECT * FROM DB.dbo.AAAAA') AS a;

如何给OPENQUERY传递参数

CREATE PROCEDURE [dbo].[prd_Test]
    @UserId INT
AS
BEGIN
    DECLARE @myUserId VARCHAR(20);
    SET @myUserId = CAST(@UserId AS VARCHAR(20));
    DECLARE @sql VARCHAR(1000);
    SET @sql = 'SELECT * FROM OPENQUERY([192.168.0.252],''SELECT * FROM [User].dbo.func_GetData(' + @myUserId + ')'')';
    EXEC(@sql);
END



[!--infotagslink--]

相关文章

  • SQL Server中row_number函数的常见用法示例详解

    这篇文章主要给大家介绍了关于SQL Server中row_number函数的常见用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08
  • C#查询SqlServer数据库并返回单个值的方法

    这篇文章主要介绍了C#查询SqlServer数据库并返回单个值的方法,涉及C#操作SQLServer数据库查询的相关技巧,需要的朋友可以参考下...2020-06-25
  • SQLServer 错误: 15404,无法获取有关 Windows NT 组/用户 WIN-8IVSNAQS8T7\Administrator 的信息

    SQLServer 错误: 15404,无法获取有关 Windows NT 组/用户 'WIN-8IVSNAQS8T7\Administrator' 的信息,错误代码 0x534。 [SQLSTATE 42000] (ConnIsLoginSysAdmin)...2021-07-15
  • SQL SERVER迁移之更换磁盘文件夹的完整步骤

    这篇文章主要给大家介绍了关于SQL SERVER迁移之更换磁盘文件夹的完整步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08
  • CentOS8安装SQLServer2019的过程

    这篇文章主要介绍了CentOS8安装SQLServer2019的步骤,本文通过命令实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
  • SqlServer 数据库 三大  范式

    本文将基于三大范式原则,结合具体的实例做简要分析,对SqlServer 数据库 三大 范式相关知识感兴趣的朋友一起看看吧...2020-07-11
  • sql server日志处理不当造成的隐患详解

    这篇文章主要给大家介绍了关于sql server日志处理不当造成的隐患的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用sql server具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-11
  • sqlserver添加sa用户和密码的实现

    这篇文章主要介绍了sqlserver添加sa用户和密码的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-07
  • PHP在Linux下连接MSSQLServer的配置方法简述(一、Sybase库)

    如果需要在Linux下访问Microsoft SQL Server或Sybase数据库,则推荐下列软件包。 SybaseCommon http://download.sybase.com/pub/ase1192_linux/sybase-common-11.9....2016-11-25
  • c#操作sqlserver数据库的简单示例

    这篇文章主要介绍了c#操作sqlserver数据库的简单示例,需要的朋友可以参考下...2020-06-25
  • C# 启动 SQL Server 服务的实例

    下面小编就为大家分享一篇C# 启动 SQL Server 服务的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-06-25
  • sql server数据库中raiserror函数用法的详细介绍

    这篇文章主要介绍了sql server数据库中raiserror函数用法的详细介绍,raiserror用于抛出一个异常或错误,让这个错误可以被程序捕捉到。对此感兴趣的可以了解一下...2020-12-08
  • sqlserver中distinct的用法(不重复的记录)

    distinct这个关键字用来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。...2020-07-11
  • SqlServer 表单查询问题及解决方法

    这篇文章主要介绍了SqlServer 表单查询问题及解决方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
  • sqlserver 批量数据替换助手V1.0版发布

    前段时间网站被挂马,数据库表中很多文本字段都被加上了一段js脚本。修复完程序漏洞之后便开始着手清理这些被注入的数据,其间参考了一些网上的方法,大都是写一个存储过程进行一个表一个表逐一清理。...2021-09-22
  • c++读取sqlserver示例分享

    这篇文章主要介绍了c++读取sqlserver的示例,需要的朋友可以参考下...2020-04-25
  • sqlserver 普通用户运行错误解决方法补充

    本方法作为Windows2003服务器安装及设置教程——MSSQL安全篇一(将MS SQL SERVER运行于普通用户下)的补充,成功解决了不能将sqlserver运行在普通用户的权限下的问题。...2016-01-27
  • win98 PWS环境下连接读取远程SQLServer

    from: http://www.planet-source-code.com/vb/scripts/ShowCode.asp?lngWId=4&txtCodeId=6518 Connect/Read Remote SQL server Using PWS in win 98 I had to t...2016-11-25
  • 在SQLSERVER2005中实现素数计算

    我将提出一个挑战,谁能用SQLSEERVER提出计算素数最好的方法, 我用了一个新的特点CTE和某些TSQL实现,但均不理想,前者(CTE)有限制,而后者(TSQL)产生一百万个素数用了7分种 你可...2016-11-25
  • C# Ado.net实现读取SQLServer数据库存储过程列表及参数信息示例

    这篇文章主要介绍了C# Ado.net实现读取SQLServer数据库存储过程列表及参数信息,结合实例形式总结分析了C#针对SQLServer数据库存储过程及参数信息的各种常见操作技巧,需要的朋友可以参考下...2020-06-25