如何sql中链接服务器语句

不及物动词 其他 18

回复

共3条回复 我来回复
  • 不及物动词的头像
    不及物动词
    这个人很懒,什么都没有留下~
    评论

    SQL中链接服务器的语句可以使用OPENROWSET函数、OPENQUERY函数、OPENDATASOURCE函数或使用sp_addlinkedserver存储过程来实现。

    1. 使用OPENROWSET函数:
    SELECT *
    FROM OPENROWSET('SQLNCLI', 'Server=服务器名称;UID=用户名;PWD=密码', 'SELECT * FROM 数据库名.表名')
    

    其中,'SQLNCLI'是使用SQL Server Native Client提供者。

    1. 使用OPENQUERY函数:
    SELECT *
    FROM OPENQUERY(服务器名称, 'SELECT * FROM 数据库名.表名')
    

    其中,服务器名称是在SQL Server中已经定义的链接服务器的名称。

    1. 使用OPENDATASOURCE函数:
    SELECT *
    FROM OPENDATASOURCE('SQLNCLI', 'Data Source=服务器名称;User ID=用户名;Password=密码')
    

    其中,'SQLNCLI'是使用SQL Server Native Client提供者。

    1. 使用sp_addlinkedserver存储过程:
      首先需要使用sp_addlinkedserver存储过程将需要链接的服务器添加到SQL Server中,然后可以通过以下语句查询链接服务器中的数据:
    SELECT *
    FROM [服务器名称].[数据库名].[dbo].[表名]
    

    其中,服务器名称是在SQL Server中已经定义的链接服务器的名称。

    以上是一些常用的SQL中链接服务器的语句,可以根据具体的需求选择使用。

    1年前 0条评论
  • fiy的头像
    fiy
    Worktile&PingCode市场小伙伴
    评论

    在SQL Server中,可以使用以下语句来连接到另一个服务器:

    1. 在SQL Server Management Studio(SSMS)中,打开新的查询窗口。

    2. 使用以下语法连接到另一个服务器:

    EXEC sp_addlinkedserver @server = 'LinkedServerName', @srvproduct = 'Any', @provider = 'SQLNCLI', @datasrc = 'ServerName\InstanceName'
    

    其中,LinkedServerName表示链接的服务器名称,ServerName表示目标服务器的名称,InstanceName表示目标服务器的实例名称。

    1. 运行以下语句以指定登录凭据(如果需要):
    EXEC sp_addlinkedsrvlogin @rmtsrvname = 'LinkedServerName', @useself = 'false', @locallogin = NULL, @rmtuser = 'username', @rmtpassword = 'password'
    

    其中,LinkedServerName表示链接的服务器名称,username表示在目标服务器上的登录名,password表示登录名对应的密码。

    1. 可选:如果目标服务器使用了不同的身份验证方法,可以使用以下语句启用受信任的身份验证:
    EXEC sp_serveroption 'LinkedServerName', 'rpc out', 'true'
    
    1. 可选:如有需要,可以使用以下语句启用位于链接服务器上的分发程序:
    EXEC sp_changedistributor_property @distributor = 'LinkedServerName', @property = 'working_directory', @value = 'C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\ReplData'
    

    其中,LinkedServerName表示链接的服务器名称,working_directory表示分发程序的工作目录路径。

    请注意,以上语句中的参数和选项需要根据实际情况进行修改和调整。连接到链接服务器后,可以在查询中使用四部分名称(linkedservername.databasename.schemaname.objectname)引用链接服务器上的对象。

    在连接服务器之前,还必须确保所使用的账户具有足够的权限来访问链接服务器上的数据库和对象。

    1年前 0条评论
  • worktile的头像
    worktile
    Worktile官方账号
    评论

    要在SQL Server中连接到另一个服务器,可以使用以下语句:

    EXEC sp_addlinkedserver 
       [ @server = ] 'linked_server', 
       [ @srvproduct = ] 'product_name',
       [ @provider = ] 'provider_name',
       [ @datasrc = ] 'data_source',
       [ @location = ] 'location',
       [ @provstr = ] 'provider_string'
    

    其中,参数说明如下:

    • @server:指定链接服务器的名称。
    • @srvproduct:指定链接服务器的产品名称,如"SQL Server"或"Oracle"等。
    • @provider:指定链接服务器的提供程序名称,如"SQLOLEDB"或"MSOLEDBSQL"等。
    • @datasrc:指定链接服务器的数据源名称或连接字符串。
    • @location:指定链接服务器的物理位置。
    • @provstr:指定链接服务器的提供程序特定连接字符串(可选)。

    例如,要连接到名为"LinkedServer"的链接服务器,产品名称为"SQL Server",提供程序为"SQLOLEDB",数据源为"LinkedServerInstance",可以使用以下语句:

    EXEC sp_addlinkedserver 
       @server = 'LinkedServer', 
       @srvproduct = 'SQL Server',
       @provider = 'SQLOLEDB',
       @datasrc = 'LinkedServerInstance'
    

    完成链接服务器的添加后,可以使用以下语句在SQL Server中执行远程查询:

    SELECT *
    FROM LinkedServer.DatabaseName.SchemaName.TableName
    

    其中,LinkedServer是链接服务器的名称,DatabaseName是链接服务器上的数据库名称,SchemaName是表所在的模式名称,TableName是表的名称。

    另外,如果链接服务器需要使用身份验证,请使用以下语句指定链接服务器的登录凭据:

    EXEC sp_addlinkedsrvlogin
       @rmtsrvname = 'LinkedServer',
       @locallogin = NULL,
       @useself = 'FALSE',
       @rmtuser = 'RemoteUserName',
       @rmtpassword = 'RemotePassword'
    

    其中,LinkedServer是链接服务器的名称,RemoteUserName是链接服务器的用户名,RemotePassword是链接服务器的密码。

    以上是在SQL Server中连接到另一个服务器的方法和操作流程。

    1年前 0条评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部