• <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>

            解決Linux/Unix下OCI程序動態庫版本的問題

            這段時間做了好幾個基礎OCI的程序,在Windows上編譯后,不需要重新編譯, 就可以適應8i/9i/10g的客戶端,但在Linux/Unix上,編譯好后到不同的版本的客戶端去運行時, 總會提示找不到動態庫libclntsh.., 這時可以用以下辦法去解決:

                第一步,修改genclntsh文件,這個文件在Oracle的bin目錄下

            #
            # Library names and locations
            CLNT_NAM=clntsh                      # (short) library name
            CLNT_VER=9.0                        # library version number
            CLNT_LNK=lib${CLNT_NAM}.so          # name of symlink to library
            CLNT_LIB=${CLNT_LNK}.${CLNT_VER}    # actual library file name
            LIB_DIR=${ORACLE_HOME}/${LIB}        # lib. destination directory

                改為:

            #
            # Library names and locations
            CLNT_NAM=clntsh                      # (short) library name
            CLNT_VER=9.0                        # library version number
            CLNT_LIB=lib${CLNT_NAM}.so          # name of symlink to library
            CLNT_LNK=${CLNT_LNK}.${CLNT_VER}    # actual library file name
            LIB_DIR=${ORACLE_HOME}/${LIB}        # lib. destination directory

                第二步,運行genclntsh重新生成客戶端的動態庫,這一步不要在正在運行的機器上做.

                第三步,用gcc去編譯程序時加上以下選項.

            gcc -o ocidemo.bin ocidemo.c -I${ORACLE_HOME}/rdbms/demo -L${ORACLE_HOME}/lib -lclntsh -Wl,-Bdynamic

                第四步,編寫一個Shell去執行OCI程序(ocidemo.bin)

            #!/bin/sh

            if [ "A${ORACLE_HOME}A" = "AA" ]; then
            echo "ORACLE_HOME environment variable not setted."
            exit
            fi

            if [ "A${LD_LIBRARY_PATH}A" = "AA" ];then
            LD_LIBRARY_PATH=/lib:/usr/lib
            fi

            if [ -d ${ORACLE_HOME}/lib32 ]; then
            LD_LIBRARY_PATH=${ORACLE_HOME}/lib32:${ORACLE_HOME}/lib:${LD_LIBRARY_PATH}
            else
            LD_LIBRARY_PATH=${ORACLE_HOME}/lib:${ORACLE_HOME}/lib64:${LD_LIBRARY_PATH}
            fi

            export LD_LIBRARY_PATH

            ocidemo.bin $*

                我在RedHat Linux和Solaris上通過以上步驟解決OCI程序的運行庫文件問題.

            posted on 2008-04-17 01:04 RedLight 閱讀(689) 評論(0)  編輯 收藏 引用 所屬分類: ORM關系對象數據庫架構

            <2013年4月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品久久久久久久影视麻豆| 久久亚洲电影| 精品久久久久中文字幕日本| 久久精品国产精品青草| 精品久久久久久久久久中文字幕| 热久久视久久精品18| 久久精品午夜一区二区福利| 久久成人永久免费播放| 亚洲精品无码专区久久久 | 麻豆亚洲AV永久无码精品久久 | 国产成人AV综合久久| 人妻无码久久精品| 国产精品久久久久久福利69堂| 久久精品国产99久久久香蕉| 久久久久亚洲AV无码专区体验| yellow中文字幕久久网| 久久香综合精品久久伊人| 四虎亚洲国产成人久久精品| 丰满少妇人妻久久久久久4| 久久久久久久亚洲Av无码| 亚洲国产精品综合久久一线| 老司机国内精品久久久久| 久久w5ww成w人免费| 亚洲中文字幕久久精品无码APP| 狠狠综合久久综合中文88| 成人资源影音先锋久久资源网| 色妞色综合久久夜夜| 久久久久亚洲爆乳少妇无 | 狠狠狠色丁香婷婷综合久久俺| 亚洲精品无码久久久久久| 人妻无码精品久久亚瑟影视| 亚洲人成无码www久久久| 内射无码专区久久亚洲| 久久天天躁狠狠躁夜夜不卡| 国产精品无码久久久久| 国产精品欧美亚洲韩国日本久久| 久久精品国产亚洲综合色| 久久99国产精品一区二区| 国产午夜精品理论片久久影视| 久久66热人妻偷产精品9| 国内精品久久人妻互换|