欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

如何使用OPENQUERY訪問另一個SQL Server

系統 1996 0
原文: 如何使用OPENQUERY訪問另一個SQL Server

在項目中,經常會遇到一個數據庫訪問另一個數據庫,【CNVFERPDB】為服務器名,【CE3】為庫名

      
        1
      
      
        SELECT
      
       Dtl.
      
        *
      
      
        2
      
      
        FROM
      
      
         CNVFERPDB. CE3.ce3.ZTLE0125 Dtl 


      
      
        3
      
      
        INNER
      
      
        JOIN
      
      
         CNVFERPDB.CE3.ce3.ZTLE0124 Mst 


      
      
        4
      
      
        ON
      
       Dtl.RECVSUPPNO 
      
        =
      
       Mst.RECVSUPPNO 
      
        AND
      
       Dtl.MANDT 
      
        =
      
      
         Mst.MANDT 


      
      
        5
      
      
        WHERE
      
       Mst.MANDT 
      
        =
      
      
        '
      
      
        100
      
      
        '
      
      
        and
      
       Dtl.BRANDCODE
      
        =
      
      
        '
      
      
        MD
      
      
        '
      
    

上面的方式是通過服務器名和庫名直接訪問,這樣有多次連接另一個服務器,執行速度會很慢

可以換做下面的形式,執行速度將得到提升:

      
         1
      
      
        SELECT
      
      
        *
      
      
         2
      
      
        FROM
      
      
        OPENQUERY
      
      
         (CNVFERPDB  


      
      
         3
      
      
            , 


      
      
         4
      
      
        '
      
      
         5
      
      
            SELECT Dtl.*  


      
      
         6
      
      
            FROM    CE3.ce3.ZTLE0125 Dtl  


      
      
         7
      
      
            INNER JOIN CE3.ce3.ZTLE0124 Mst  


      
      
         8
      
      
            ON Dtl.RECVSUPPNO = Mst.RECVSUPPNO  AND Dtl.MANDT = Mst.MANDT  


      
      
         9
      
      
            WHERE Mst.MANDT = 
      
      
        ''
      
      
        100
      
      
        ''
      
      
         and Dtl.BRANDCODE=
      
      
        ''
      
      
        MD
      
      
        ''
      
      
        10
      
      
        '
      
      
        11
      
       ) 
    
    
OPENQUERY ( linked_server ,'query' )
使用注意事項:
  linked_server?
    表示鏈接服務器名稱的標識符。
  ' query '

    在鏈接服務器中執行的查詢字符串。 該字符串的最大長度為 8 KB。


補充
      
         1
      
      
        declare
      
      
        @Day
      
      
        VARCHAR
      
      (
      
        10
      
      )
      
        =
      
      
        CONVERT
      
      (
      
        CHAR
      
      (
      
        8
      
      ),
      
        DATEADD
      
      (
      
        DAY
      
      ,
      
        -
      
      
        1
      
      ,
      
        GETDATE
      
      ()),
      
        112
      
      
        )


      
      
         2
      
      
         3
      
      
        --
      
      
        set @Day='20140605'
      
      
         4
      
      
         5
      
      
        IF
      
      
        EXISTS
      
      (
      
        select
      
      
        *
      
      
        from
      
       AppLog 
      
        where
      
       Dates
      
        =
      
      
        @Day
      
      
        )


      
      
         6
      
      
        return
      
      
         7
      
      
         8
      
      
        declare
      
      
        @sql
      
      
        VARCHAR
      
      (
      
        2000
      
      )
      
        =
      
      
        '
      
      
        select * 


      
      
         9
      
      
        INTO #temp


      
      
        10
      
      
        from openquery


      
      
        11
      
      
        ([CNSASPLOGDB01],


      
      
        12
      
      
        ''
      
      
        13
      
      
        select 


      
      
        14
      
      
        A.ProgramId


      
      
        15
      
      
        ,
      
      
        '''''
      
      
        +
      
      
        @Day
      
      
        +
      
      
        '''''
      
      
         AS Dates


      
      
        16
      
      
        ,COUNT(Duration) as Count


      
      
        17
      
      
        ,SUM(CAST(Duration AS DECIMAL(12,3)))/1000 AS SumTime


      
      
        18
      
      
        ,AVG(CAST(Duration AS DECIMAL(12,3)))/1000 as AvgTime


      
      
        19
      
      
        ,MAX(CAST(Duration AS DECIMAL(12,3)))/1000 as MaxTime


      
      
        20
      
      
        from 


      
      
        21
      
      
        (


      
      
        22
      
      
        select * from LogCSLK01.dbo.AppLog_
      
      
        '
      
      
        +
      
      
        @Day
      
      
        +
      
      
        '
      
      
         with(nolock)


      
      
        23
      
      
        union


      
      
        24
      
      
        select * from LogCSLK02.dbo.AppLog_
      
      
        '
      
      
        +
      
      
        @Day
      
      
        +
      
      
        '
      
      
         with(nolock)


      
      
        25
      
      
        union


      
      
        26
      
      
        select * from LogCSLK03.dbo.AppLog_
      
      
        '
      
      
        +
      
      
        @Day
      
      
        +
      
      
        '
      
      
         with(nolock)


      
      
        27
      
      
        ) A


      
      
        28
      
      
        group by A.ProgramId


      
      
        29
      
      
        ''
      
      
        30
      
      
        )


      
      
        31
      
      
        32
      
      
        insert into AppLog


      
      
        33
      
      
        select * 


      
      
        34
      
      
        from #temp


      
      
        35
      
      
        36
      
      
        drop table  #temp


      
      
        37
      
      
        '
      
      
        38
      
      
        --
      
      
        print @sql
      
      
        39
      
      
        40
      
      
        exec
      
      (
      
        @sql
      
      )
    

?

如何使用OPENQUERY訪問另一個SQL Server


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久精品国产一区二区三区不卡 | 亚洲日韩欧洲无码av夜夜摸 | 天天射影院| 日本激情视频网站w | 婷婷激情综合色五月久久竹菊影视 | 亚洲一区二区三 | 国产一区高清 | 久久最新精品 | 91精品一区二区三区久久久久久 | 欧美日韩性高爱潮视频 | 久久精品人人做人人爽 | 久久99精品久久 | 亚洲国产一区二区三区四区五区 | 日本色综合 | 亚洲国产综合精品 | 亚洲一级免费视频 | 久青青| 欧美日韩在线视频观看 | 性高湖久久久久久久久aaaaa | 国产在线精品视频 | 亚洲www啪成人一区二区麻豆 | 一区影院| 亚洲美女精品 | 激情视频免费在线观看 | 国产精品成人无码A片免费网址 | 一区二区久久 | 久久久国产精品免费A片蜜臀 | www.伊人| 91精品国产综合久久久蜜臀粉嫩 | 欧美精品黄页免费高清在线 | 99国产精品视频免费观看 | a在线视频观看 | 91丨九色丨首页在线观看 | 欧美国产高清欧美 | 国产在线看片 | 日本欧美日韩 | 日韩欧美在线视频 | 99久久精品免费观看区一 | 日韩欧美在线播放 | 99av.com| 欧美精品成人 |