zoukankan      html  css  js  c++  java
  • 跨数据库数据交流

    通常情况下,我们的CRUD操作都在单一数据库中进行。但是,也可能会遇到需要进行跨数据交流的情况。对此,我以跨数据库进行表的访问为例,稍微总结了下。

    一、同SQL SERVER

    这个最简单。直接在表名前加上"[数据库名]."就可以了。

    例:

    SELECT * FROM [DestinationDBName].dbo.DestinationTableName

    二、跨SQL SERVER

     主要介绍两种方法:

    (一)通过链接服务器

    1.先执行系统存储过程 sp_addlinkedserver :

    EXEC sp_addlinkedserver  
    @server='DestinationDBAlias',--目标数据库的别名,在连接并登录后,就可以用它来访问数据
    @srvproduct='',
    @provider='SQLOLEDB',
    @datasrc='DestinationServerIPServerName'--通常用"IP端口名"组成,如果服务器上只装了一个MSSQL SERVER,或者装了多个MS SQLSERVER,但要访问的是默认端口,就不用加端口名

    2.再执行系统存储过程 sp_addlinkedsrvlogin:

    EXEC sp_addlinkedsrvlogin 
    @rmtsrvname='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
    @useself='false',
    @locallogin=NULL,
    @rmtuser='UserName',
    @rmtpassword='Password'

    3.现在,我们可以通过目标数据库别名访问数据:

    例:

    SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName

    4.使用结束,不要忘了断开与目标数据库的连接:

    EXEC sp_dropserver 
    @server='DestinationDBAlias',--注意这里的名字应与第一步sp_addlinkedserver中@server值一致
    @droplogins='droplogins'

    (二)使用OPENDATASOURCE/OPENROWSET连接远程服务器

    SELECT * FROM OPENDATASOURCE
    ('SQLOLEDB', --provider_name 'Data Source=DestinationServerIP;User ID=UserName;Password=Password' --provider_string(datasource;user_id;password) ).[DestinationDBAlias].dbo.DestinationTableName SELECT * FROM OPENROWSET ('SQLOLEDB',--provider_name 'DestinationServerIP';'UserName';'Password',--provider_string(datasource;user_id;password) 'SELECT * FROM [DestinationDBAlias].dbo.DestinationTableName')--query_string

    函数OPENQUERY也能实现跨服务器访问数据,但它是基于已经建立链接服务器的基础上来操作的,应属第一种方法,在此不再赘述。

  • 相关阅读:
    【转发】淘宝下单高并发解决方案
    ImageLoader的使用
    学习写接口回调
    EventBus的使用
    ListView显示多种类型的item
    GridView规则显示图片
    ViewPager滑动标签-PagerSlidingTabStrip的使用
    Json解析要点
    LISTVIEW嵌套GRIDVIEW的一些处理(点击GRIDVIEW的条目,能够显示他在LISTVIEW中的位置)(对这篇文章的优化处理,不每次都new onItemClickListener)
    SVN分支的创建,合并,与销毁和相关操作
  • 原文地址:https://www.cnblogs.com/Figgy/p/4707313.html
Copyright © 2011-2022 走看看