• <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預(yù)處理SQL語(yǔ)句:"insert into mytable (myimg) values (empty_blob()) returning myimg into :pImg"
            ?b、調(diào)用OCIDescriptorAlloc,用參數(shù)OCI_DTYPE_LOB,獲得一個(gè)LOB的句柄
            ?c、用OCIStmtBindByPos或者OCIStmtBindByName,把LOB句柄和參數(shù):pImg綁定
            ?d、OCIStmtExecute執(zhí)行
            ?e、OCILobWrite往LOB里面寫(xiě)數(shù)據(jù)
            ?f、commit和釋放資源等等
            ?
            ?問(wèn)題是這個(gè)SQL語(yǔ)句也太特別了,和其他數(shù)據(jù)庫(kù)的SQL不一樣。但是在java的實(shí)現(xiàn)中,并不需要這么奇怪的語(yǔ)法。
            ?insert into mytable (myimg) values(?)
            ?就足夠了。
            ?在我們的應(yīng)用中,能夠統(tǒng)一同一種SQL的寫(xiě)法當(dāng)然是最好的,最好就是:
            ?insert into mytable (myimg) values (:pImg)?那就和其他的數(shù)據(jù)處理一致了。
            ?
            ?做了很多的嘗試,終于找到解決的方法:
            ?a、OCIStmtPrepare預(yù)處理SQL語(yǔ)句:"insert into mytable (myimg) values (:pImg)"
            ?b、調(diào)用OCIDescriptorAlloc,用參數(shù)OCI_DTYPE_LOB,獲得一個(gè)LOB的句柄
            ?c、通過(guò)OCILobCreateTemporary函數(shù),為L(zhǎng)OB句柄創(chuàng)建臨時(shí)LOB對(duì)象
            ?d、OCILobWriteAppend往LOB句柄寫(xiě)數(shù)據(jù)
            ?e、用OCIStmtBindByPos或者OCIStmtBindByName,把LOB句柄和參數(shù):pImg綁定
            ?f、OCIStmtExecute執(zhí)行
            ?g、commit和釋放資源等等
            ?
            ?經(jīng)過(guò)簡(jiǎn)單的封裝,LOB操作簡(jiǎn)單很多了:
            ?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、空字符串
            ?插入一個(gè)空字符串,OCIBindByPos/OCIBindByName的時(shí)候,那個(gè)字符串的數(shù)據(jù)類(lèi)型,不能是SQLT_LVC,用SQLT_CHR倒是沒(méi)有問(wèn)題。
            ?具體為什么,只有Oracle自己知道了。
            ?
            3、指定IP連接Oracle
            ?通過(guò)OCIServerAttach里面指定綁定的SID連接數(shù)據(jù)庫(kù)。用SID連接Oracle當(dāng)然有它的好處。奇怪的是JDBC能用IP和Port指定連接哪個(gè)Oracle。
            ?找遍OCI的幫助都找不到IP連接方法。google了很久,找到解決的方法,自己生成SID:
            ?string strSID = "(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=%1)(PORT=%2)))(CONNECT_DATA=(SERVICE_NAME=%3)))";
            ?里面的%1設(shè)為Oracle服務(wù)器的IP;%2設(shè)為Oracle服務(wù)器的Port,一般是1521;%3就是database的名字。
            ?把這個(gè)字符串放入OCIServerAttach

            ?

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

              ------------------
              這是完全不同的兩種連接機(jī)制:
              JDBC(thin驅(qū)動(dòng))連接到Oracle是不需要Oracle客戶(hù)端的,通過(guò)tcp/ip直連。
              OCI必須依賴(lài)于Oracle客戶(hù)端dll,連接串的寫(xiě)法規(guī)則其實(shí)是OCI的要求。  回復(fù)  更多評(píng)論   
            • # re: OCI訪問(wèn)Oracle的一些刁鉆問(wèn)題
              222
              Posted @ 2011-03-17 16:12
              OCIServerAttach 的服務(wù)字段 按格式 服務(wù)器的IP:服務(wù)器的Port/database的名字 就可以有你怎么復(fù)雜么  回復(fù)  更多評(píng)論   
            • # re: OCI訪問(wèn)Oracle的一些刁鉆問(wèn)題[未登錄](méi)
              paul
              Posted @ 2014-09-16 20:06
              這個(gè)有沒(méi)有具體的代碼?目前正好遇上這個(gè)問(wèn)題了  回復(fù)  更多評(píng)論   
             
            久久中文精品无码中文字幕| 综合久久国产九一剧情麻豆| 国产精品久久久久久久app| 激情伊人五月天久久综合| 欧美国产成人久久精品| 久久九九久精品国产免费直播| 99久久99久久精品国产| 国内精品伊人久久久久影院对白 | 久久露脸国产精品| 久久久久国产一区二区| 久久久精品日本一区二区三区| 久久久久久亚洲精品无码| 日批日出水久久亚洲精品tv| 欧美亚洲国产精品久久久久| 2021国产精品久久精品| 人妻久久久一区二区三区| 久久99精品综合国产首页| 99久久人人爽亚洲精品美女| 精品国产乱码久久久久久浪潮| 热久久国产欧美一区二区精品| 亚洲午夜无码AV毛片久久| 亚洲精品无码久久久久sm| 99久久精品国产麻豆| 久久青青草原精品国产软件| 久久亚洲精品国产精品婷婷| 一本色道久久88—综合亚洲精品| 国产∨亚洲V天堂无码久久久| 狠狠色综合久久久久尤物| 中文字幕无码久久久| 91久久婷婷国产综合精品青草| 国产99久久久久久免费看 | 亚洲国产日韩欧美综合久久| 亚洲αv久久久噜噜噜噜噜| 久久九九亚洲精品| 久久精品人人做人人爽电影| 久久精品国产亚洲沈樵| 欧美久久久久久| 精品国产热久久久福利| 国产精品一区二区久久不卡| 久久综合久久鬼色| 夜夜亚洲天天久久|