• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            cyt

            1、CLOG/BLOG的插入
            ?找了很多OCI的例子以及一些PHP的例子,基本上都是同一種做法:
            ?a、OCIStmtPrepare預處理SQL語句:"insert into mytable (myimg) values (empty_blob()) returning myimg into :pImg"
            ?b、調用OCIDescriptorAlloc,用參數OCI_DTYPE_LOB,獲得一個LOB的句柄
            ?c、用OCIStmtBindByPos或者OCIStmtBindByName,把LOB句柄和參數:pImg綁定
            ?d、OCIStmtExecute執行
            ?e、OCILobWrite往LOB里面寫數據
            ?f、commit和釋放資源等等
            ?
            ?問題是這個SQL語句也太特別了,和其他數據庫的SQL不一樣。但是在java的實現中,并不需要這么奇怪的語法。
            ?insert into mytable (myimg) values(?)
            ?就足夠了。
            ?在我們的應用中,能夠統一同一種SQL的寫法當然是最好的,最好就是:
            ?insert into mytable (myimg) values (:pImg)?那就和其他的數據處理一致了。
            ?
            ?做了很多的嘗試,終于找到解決的方法:
            ?a、OCIStmtPrepare預處理SQL語句:"insert into mytable (myimg) values (:pImg)"
            ?b、調用OCIDescriptorAlloc,用參數OCI_DTYPE_LOB,獲得一個LOB的句柄
            ?c、通過OCILobCreateTemporary函數,為LOB句柄創建臨時LOB對象
            ?d、OCILobWriteAppend往LOB句柄寫數據
            ?e、用OCIStmtBindByPos或者OCIStmtBindByName,把LOB句柄和參數:pImg綁定
            ?f、OCIStmtExecute執行
            ?g、commit和釋放資源等等
            ?
            ?經過簡單的封裝,LOB操作簡單很多了:
            ?TDBConnection conn = TDatabase::getConnection( strConnection );
            ?TDBStatement dbStatement(conn.getStatement());
            ?dbStatement.prepareSQL( "insert into mytable (myimg) values (:pImg)" );
            ?dbStatement.getParam("pImg").attachInputStream( fStream );
            ?dbStatement.execSQL();
            ?conn.commite();
            ?
            2、空字符串
            ?插入一個空字符串,OCIBindByPos/OCIBindByName的時候,那個字符串的數據類型,不能是SQLT_LVC,用SQLT_CHR倒是沒有問題。
            ?具體為什么,只有Oracle自己知道了。
            ?
            3、指定IP連接Oracle
            ?通過OCIServerAttach里面指定綁定的SID連接數據庫。用SID連接Oracle當然有它的好處。奇怪的是JDBC能用IP和Port指定連接哪個Oracle。
            ?找遍OCI的幫助都找不到IP連接方法。google了很久,找到解決的方法,自己生成SID:
            ?string strSID = "(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=%1)(PORT=%2)))(CONNECT_DATA=(SERVICE_NAME=%3)))";
            ?里面的%1設為Oracle服務器的IP;%2設為Oracle服務器的Port,一般是1521;%3就是database的名字。
            ?把這個字符串放入OCIServerAttach

            ?

            posted on 2006-04-14 22:24 cyt 閱讀(4551) 評論(3)  編輯 收藏 引用 所屬分類: Work
            Comments
            • # re: OCI訪問Oracle的一些刁鉆問題
              myy
              Posted @ 2006-12-22 15:10
              ....奇怪的是JDBC能用IP和Port指定連接哪個Oracle。....

              ------------------
              這是完全不同的兩種連接機制:
              JDBC(thin驅動)連接到Oracle是不需要Oracle客戶端的,通過tcp/ip直連。
              OCI必須依賴于Oracle客戶端dll,連接串的寫法規則其實是OCI的要求。  回復  更多評論   
            • # re: OCI訪問Oracle的一些刁鉆問題
              222
              Posted @ 2011-03-17 16:12
              OCIServerAttach 的服務字段 按格式 服務器的IP:服務器的Port/database的名字 就可以有你怎么復雜么  回復  更多評論   
            • # re: OCI訪問Oracle的一些刁鉆問題[未登錄]
              paul
              Posted @ 2014-09-16 20:06
              這個有沒有具體的代碼?目前正好遇上這個問題了  回復  更多評論   
             
            色婷婷综合久久久久中文| 国产精品久久一区二区三区| 一级a性色生活片久久无少妇一级婬片免费放| 国产精品欧美久久久久天天影视 | 成人久久免费网站| 久久精品国产亚洲欧美| 久久婷婷五月综合色奶水99啪| AV无码久久久久不卡蜜桃| 无码国内精品久久人妻麻豆按摩| 久久久久亚洲AV无码永不| 久久国产V一级毛多内射| 久久婷婷五月综合国产尤物app | 久久精品国产亚洲77777| 日本亚洲色大成网站WWW久久| 狠狠色丁香久久婷婷综合五月| 日本亚洲色大成网站WWW久久| 亚洲午夜久久久精品影院| 国产精品久久久久久吹潮| 国产成人精品综合久久久| 久久人妻少妇嫩草AV无码蜜桃| av无码久久久久久不卡网站| 99久久无色码中文字幕人妻| 亚洲美日韩Av中文字幕无码久久久妻妇 | 国内精品久久久久久久97牛牛| 亚洲国产美女精品久久久久∴| 九九精品久久久久久噜噜| 中文精品99久久国产| 伊人久久大香线蕉综合热线| 国产免费福利体检区久久| 国产三级观看久久| 久久天天躁狠狠躁夜夜2020 | 久久只这里是精品66| 麻豆久久久9性大片| 久久亚洲精品成人无码网站| 少妇熟女久久综合网色欲| 四虎国产精品成人免费久久| 18岁日韩内射颜射午夜久久成人| 亚洲愉拍99热成人精品热久久 | 久久成人国产精品一区二区| 亚洲国产成人久久一区久久| 久久久久亚洲AV无码观看|