• sql server 跨库操作


    SELECT *FROM OPENDATASOURCE('SQLOLEDB','Data Source=sql服务器名;User ID=用户名;Password=密码;').PersonDb.dbo.Table_1

    exec sp_dropserver 'SQL2','droplogins'

    exec sp_addlinkedserver @server= 'SQL2', @srvproduct= '', 
    @provider='SQLNCLI', @datasrc = 'sql服务器名' --登录链接服务器 
    exec sp_addlinkedsrvlogin @rmtsrvname = 'SQL2', 
    @useself = 'false ', @locallogin = null, 
    @rmtuser ='用户名', @rmtpassword = '密码'

    select * from SQL2.PersonDb.dbo.Table_1

     

    -------------------------------------------------------------------------------------------------------

     

     

    用openrowset连接远程SQL或插入数据

     

    --如果只是临时访问,可以直接用openrowset

     

    --查询示例

     

    select * from openrowset('SQLOLEDB'

     

    ,'sql服务器名';'用户名';'密码'

     

    ,数据库名.dbo.表名)

     

     

     

    --导入示例

     

    select * into 表 from openrowset('SQLOLEDB'

     

    ,'sql服务器名';'用户名';'密码'

     

    ,数据库名.dbo.表名)

     

     

    --创建链接服务器

     

    exec sp_addlinkedserver  'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'

     

    exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'

     

    go

     

     

    --查询示例

     

    select * from srv_lnk.数据库名.dbo.表名

     

     

    --导入示例

     

    select * into 表 from srv_lnk.数据库名.dbo.表名

     

     

    --以后不再使用时删除链接服务器

     

    exec sp_dropserver 'srv_lnk','droplogins'

     

    go

     

    --下面的示例访问来自某个表的数据,该表在 SQL Server 的另一个实例中。

     

    SELECT *FROM OPENDATASOURCE('SQLOLEDB','Data Source=ServerName;User ID=MyUID;Password=MyPass').Northwind.dbo.Categories

     

    下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。

     

    SELECT *FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:Financeaccount.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

     

     

     

    例如:

     

    SELECT *

     

    FROM OPENQUERY(Far_MDB, 'SELECT * FROM MDB_Member')

     

    这就是从我的链接服务器当中去查询MDB_Member表的数据

     

    备注:

     

    1、关于链接服务器的详细情况请参阅联机丛书中的sp_addlinkedserver、 sp_addlinkedsrvlogin、sp_addserver、sp_dropserver、sp_serveroption、sp_linkedservers等系统级存储过程。

     

    2、关于此链接服务器的创建及其使用在不同环境下(全部内网服务器、一内网一公网服务器、全公网服务器)测试,均告通过。

     

    3、有时候在存储过程中访问链接服务器的时候可能会碰到如下的提示,必须要对ANSI warning 和ANSI nulls进行设置,这时候按照如下的方法进行设置:

     

    设置本地数据库的属性-->连接-->选上ANSI warning 和 ANSI nulls

     

    如何用sql语句进行跨库查询

     

    在机器B上的数据库database2中创建一个临时表#tmp,

     

    内容就是机器A上的数据库database1里面的Table1。

     

    如何用sql语句完成?(不借用dts等)

     

    SQL code --创建链接服务器

     

    exec sp_addlinkedserver  'ITSV','','SQLOLEDB','远程服务器名或ip地址'

     

    exec sp_addlinkedsrvlogin 'ITSV','false',null,'用户名','密码'

     

    --查询示例

     

    select * from ITSV.数据库名.dbo.表名

     

    --导入示例

     

    select * into 表 from ITSV.数据库名.dbo.表名

     

    --以后不再使用时删除链接服务器

     

    exec sp_dropserver 'ITSV','droplogins'

     

    --连接远程/局域网数据(openrowset/openquery/opendatasource)

     

    --1、openrowset

     

    --查询示例

     

    select * from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)

     

    --生成本地表

     

    select * into 表 from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)

     

    --把本地表导入远程表

     

    insert openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)

     

    select *from 本地表

     

    --更新本地表

     

    update b

     

    set b.列A=a.列A

     

    from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)as a inner join 本地表 b

     

    on a.column1=b.column1

     

    --openquery用法需要创建一个连接

     

    --首先创建一个连接创建链接服务器

     

    exec sp_addlinkedserver  'ITSV','','SQLOLEDB','远程服务器名或ip地址'

     

    --查询

     

    select *

     

    FROM openquery(ITSV, 'SELECT *  FROM 数据库.dbo.表名')

     

    --把本地表导入远程表

     

    insert openquery(ITSV, 'SELECT *  FROM 数据库.dbo.表名')

     

    select * from 本地表

     

    --更新本地表

     

    update b

     

    set b.列B=a.列B

     

    FROM openquery(ITSV, 'SELECT * FROM 数据库.dbo.表名') as a

     

    inner join 本地表 b on a.列A=b.列A

     

    --3、opendatasource/openrowset

     

    SELECT   *

     

    FROM   opendatasource('SQLOLEDB', 'Data Source=ip/ServerName;User ID=登陆名password=密码' ).test.dbo.roy_ta

     

    --把本地表导入远程表

     

    insert opendatasource('SQLOLEDB', 'Data Source=ip/ServerName;User ID=登陆名password=密码').数据库.dbo.表名

     

    select * from 本地表

     

    用   链接服务器

     

    OPENROWSET

     

    OPENDATASOURCE

     

    都可以

     

    链接服务器.database1.dbo.table1

     

    链接服务器.database1.dbo.table1

     

    SQL code

     

    select * into #

     

    from openrowset('sqloledb','ip';'sa';'','select * from pubs.dbo.jobs')

  • 相关阅读:
    IndexFlatL2、IndexIVFFlat、IndexIVFPQ三种索引方式示例
    Faiss流程与原理分析
    快速排序(快排)
    SSM框架整合Demo
    基于Logistic回归和sigmoid函数的分类算法推导
    Libsvm java工程实践
    LibSvm流程及java代码测试
    排除文件中空行和注释行内容
    linux三剑客-sed命令使用方法
    文件中添加多行内容方法
  • 原文地址:https://www.cnblogs.com/shanhe/p/3679984.html
Copyright © 2020-2023  润新知