<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    海鷗航際

    JAVA站
    posts - 11, comments - 53, trackbacks - 1, articles - 102

    Oracle9i中的SQL*Plus

    Posted on 2005-02-03 21:05 海天一鷗 閱讀(155) 評論(0)  編輯  收藏 所屬分類: Java數據庫技術

    在Oracle9i中, SQL*Plus現在不僅能接受文件名當作腳本地址,還可以接受HTTP或是FTP地址當作腳本地址來源。舉例來說,通過“@http://www.mycorp.com/sql/setup.sql”這條命令就可以從這個網址裝載SQL腳本,然后在當前的運行環境下運行。而“@@”命令能知道它當前正在從一個URL上運行,所以會從相同的位置裝載腳本。舉例來說,如果上述裝載的腳本包含以下代碼的話,那么每個SQL腳本將根據給定的URL被裝載。

    <a target="_blank"><IMG SRC="http://m2.cn.doubleclick.net/1012548/mpu_mymai.swf " WIDTH=468 HEIGHT=60 BORDER=0 ></a>

    REM - setup script
    @@tables.sql
    @@indexes.sql
    @@code.sql

    有些DBA希望集中維護位于一個遠程位置并且可以被不同位置的數據庫執行的腳本,這對于他們來說是有價值的。這對于那些因沒有SQL*Net而不能連接數據庫,但能通過HTTP使用腳本的客戶是特別有用的。

    通過HTTP協議,腳本可以根據Web服務器的輸入參數產生。舉例來說,http://www.mycorp.com/cgi-bin/setup.pl?host=bart就將參數host=bart傳遞給CGI-BIN腳本。SQL *Plus有其單獨的參數傳遞工具。

    在腳本被裝載之后,這些參數被綁定起來用于定義參數。命令@@tables.sql mytablespace將從相同的相關目錄裝載“tables.sql”這個腳本,然后mytablespace 將被綁定到SQL * Plus的&1參數上。 對于@URL在功能上有一個差別,那就是.sql擴展是不可選擇的

    在Oracle8i中模擬@URL

    這個特征的一個缺點就是他好像不支持HTTP代理。腳本只有通過直接的連接才能夠被裝載。在Oracle8i中的一個變通的通過使用代理進入或者是模擬這個功能實現的腳本如下:

    REM -- http_at.sql
    set feedback off
    set linesize 255
    set serveroutput on size 64000
    set trimspool on
    spool test.sql
    declare
        l_pieces utl_http.html_pieces;
        l_piece     varchar2(2000);
        l_url varchar2(2048) := '&1';
        l_maxline integer := 255;
        l_index integer;
        l_stub      varchar2(255);
        l_proxy varchar2(2048) := 'proxy.mycomp.com:8000';
    begin
        l_pieces := utl_http.request_pieces(l_url,1000,l_proxy);
        for i in l_pieces.first .. l_pieces.last loop
            l_piece := l_pieces(i);
            while length(l_piece) > l_maxline loop
                l_stub := substr(l_piece,1,l_maxline);
                l_index := length(l_stub);
                while l_index > 0 and substr(l_stub,l_index,1) != chr(10) loop
                    l_index := l_index - 1;
                end loop;
                l_stub := substr(l_piece,1,l_index-1);
                l_piece := substr(l_piece,l_index+1);
                dbms_output.put_line(l_stub);
            end loop;
            dbms_output.put_line(l_piece);
        end loop;
    end;
    /
    spool off;

    主站蜘蛛池模板: 麻豆高清免费国产一区| 三级黄色片免费看| 日韩不卡免费视频| 亚洲精品第一国产综合精品| 免费毛片在线看不用播放器| 亚洲综合无码AV一区二区| rh男男车车的车车免费网站| 伊人久久亚洲综合| a级毛片免费在线观看| 亚洲精品午夜无码电影网| 久久国产精品免费视频| 亚洲第一二三四区| 久久久久国色AV免费看图片| 亚洲а∨精品天堂在线| 啊灬啊灬别停啊灬用力啊免费看| 曰批免费视频播放在线看片二| 亚洲国产小视频精品久久久三级| fc2成年免费共享视频18| 人人狠狠综合久久亚洲88| 7m凹凸精品分类大全免费| 亚洲日韩图片专区第1页| 免费毛片a在线观看67194 | 亚洲成色在线综合网站 | 免费高清资源黄网站在线观看| 亚洲av无码片vr一区二区三区| 亚洲精品国产精品乱码不卞| 色www永久免费| 亚洲伊人久久大香线蕉在观| 在线免费观看中文字幕| 无码精品人妻一区二区三区免费| 亚洲色成人中文字幕网站| 16女性下面扒开无遮挡免费| 亚洲AV第一成肉网| 亚洲人JIZZ日本人| 青青青国产在线观看免费网站| 无码天堂va亚洲va在线va| 亚洲色无码一区二区三区| 成年黄网站色大免费全看| 国产亚洲情侣久久精品| 亚洲国产一区二区三区青草影视| 好吊妞在线新免费视频|