SqlServer 远程执行存储过程或其他非DML语句
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
相关文章
SQL Server中row_number函数的常见用法示例详解
这篇文章主要给大家介绍了关于SQL Server中row_number函数的常见用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08- 这篇文章主要介绍了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迁移之更换磁盘文件夹的完整步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-08
- 这篇文章主要介绍了CentOS8安装SQLServer2019的步骤,本文通过命令实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
- 本文将基于三大范式原则,结合具体的实例做简要分析,对SqlServer 数据库 三大 范式相关知识感兴趣的朋友一起看看吧...2020-07-11
- 这篇文章主要给大家介绍了关于sql server日志处理不当造成的隐患的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用sql server具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧...2020-07-11
- 这篇文章主要介绍了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数据库的简单示例,需要的朋友可以参考下...2020-06-25
- 下面小编就为大家分享一篇C# 启动 SQL Server 服务的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-06-25
sql server数据库中raiserror函数用法的详细介绍
这篇文章主要介绍了sql server数据库中raiserror函数用法的详细介绍,raiserror用于抛出一个异常或错误,让这个错误可以被程序捕捉到。对此感兴趣的可以了解一下...2020-12-08- distinct这个关键字用来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。...2020-07-11
- 这篇文章主要介绍了SqlServer 表单查询问题及解决方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
- 前段时间网站被挂马,数据库表中很多文本字段都被加上了一段js脚本。修复完程序漏洞之后便开始着手清理这些被注入的数据,其间参考了一些网上的方法,大都是写一个存储过程进行一个表一个表逐一清理。...2021-09-22
- 这篇文章主要介绍了c++读取sqlserver的示例,需要的朋友可以参考下...2020-04-25
- 本方法作为Windows2003服务器安装及设置教程——MSSQL安全篇一(将MS SQL SERVER运行于普通用户下)的补充,成功解决了不能将sqlserver运行在普通用户的权限下的问题。...2016-01-27
- 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
- 我将提出一个挑战,谁能用SQLSEERVER提出计算素数最好的方法, 我用了一个新的特点CTE和某些TSQL实现,但均不理想,前者(CTE)有限制,而后者(TSQL)产生一百万个素数用了7分种 你可...2016-11-25
C# Ado.net实现读取SQLServer数据库存储过程列表及参数信息示例
这篇文章主要介绍了C# Ado.net实现读取SQLServer数据库存储过程列表及参数信息,结合实例形式总结分析了C#针对SQLServer数据库存储过程及参数信息的各种常见操作技巧,需要的朋友可以参考下...2020-06-25