SQL server 创建链接服务器

前言

当业务需要访问多个数据库时,可以使用链接服务器来再当前的数据库中操作另外一个数据库。 本文讲述2种创建方法:1使用SSMS客户端直接创建 2执行sql代码创建。


使用SSMS客户端直接创建

1.打开Microsoft SQL Server Management Studio
2.打开服务器对象–>右键链接服务器–>点击新建链接服务器
在这里插入图片描述
3.在常规选项卡中 输入一个自定义的别名–>在数据源选项 输入需要链接的数据库地址和端口号
在这里插入图片描述
4.在安全性选项卡中 选择(使用此安全上下文建立连接)然后输入链接数据库的登录账号和密码
在这里插入图片描述
5.在服务器选项中设置自己需要的 点击确定。
在这里插入图片描述
6.测试
在这里插入图片描述

执行sql代码创建

EXEC master.dbo.sp_addlinkedserver @server = N'TEST', @srvproduct=N'TEST', @provider=N'SQLNCLI', @datasrc=N'127.147.157.17,1433'
 /* For security reasons the linked server remote logins password is changed with ######## */
EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'TEST',@useself=N'False',@locallogin=NULL,@rmtuser=N'sa',@rmtpassword='########'

总结

创建了链接服务器可以方便的在当前数据库直接执行其他数据库SQL语句,方便业务的扩展。


SQL Server中,要添加链接服务器并设置权限,你需要按照以下步骤操作: 1. 登录到主数据库服务器:首先登录到拥有足够权限管理链接服务器SQL Server实例。 2. 创建链接服务器:运行T-SQL命令创建链接服务器,语法类似: ```sql CREATE SERVER [server_name] ON (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = remote_host)(PORT = remote_port)) (SERVER_NAME = remote_server) (INSTANCE_NAME = [instance_name]) [(ENCRYPTION = {ON | OFF}][, ...]]) ``` 其中,`remote_host`、`remote_port`、`remote_server`和`instance_name`分别是你需要连接的远程服务器的地址、端口、名称以及实例名。 3. 添加登陆账户:为链接服务器指定一个用户或角色,允许从该服务器上访问数据。例如: ```sql GRANT EXECUTE AS LOGIN = 'remote_username' TO LINKedsERVER; ``` 或者将用户添加到服务器的角色: ```sql sp_addlinkedsrvlogin @rmtsrvname = 'server_name',@useself = 'true',@locallogin = NULL, @rmtlogin = 'remote_username' ``` 4. 设置权限:为特定数据库或表授予访问权限,如SELECT、INSERT等。例如: ```sql EXEC sp_addlinkedsrvlogin @rmtsrvname = 'server_name', @useself = 'false', @locallogin = 'your_username', @rmtlogin = 'remote_username', @password = 'your_password'; GRANT SELECT ON [remote_database].[table_name] TO your_username; ``` 5. 测试链接和权限:通过使用`OPENQUERY`或`EXECUTE AS OWNER`检查连接是否成功,并测试授权是否生效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值