AIX平臺Oracle ODBC安裝手冊

尛樣兒發表於2010-07-04

1 環境
# oslevel -s
6100-05-01-1016
# bootinfo -K
64

2 下載
unixODBC

unixODBC-2.3.0.tar.gz

Oracle ODBC Driver

basic-10.2.0.4.0-aix-ppc32.zip
odbc-10.2.0.4.0-aix-ppc32.zip

注意:在測試環境中,unix是64位的作業系統,但是unixODBC無法make成64bit的程式,所以在這裡只能用32位的驅動,如果使用64bit的驅動,將在連線時報驅動無法找到的錯誤。

unixODBC2.2.13+
$ CPPFLAGS="-DBUILD_LEGACY_64_BIT_MODE -DSIZEOF_LONG_INT=8"
$ export CPPFLAGS
$ ./configure --enable-gui=no --enable-drivers=no
$ make
$ cd exe
$ ./odbc_config --ulen
-DSIZEOF_SQLULEN=4
如果-DSIZEOF_SQLULEN=4表示32bit程式,如果-DSIZEOF_SQLULEN=8表示64bit程式。
參考:
http://www.easysoft.com/developer/interfaces/odbc/64-bit.html#unix


將所有檔案上傳至伺服器的/opt/odbc/目錄下。

3 安裝必要的RPM包(root使用者)
gcc-4.2.0-3.aix6.1.ppc.rpm
libffi-devel-4.2.0-3.aix6.1.ppc.rpm
libstdc++-devel-4.2.0-3.aix6.1.ppc.rpm
libffi-4.2.0-3.aix6.1.ppc.rpm
libgcc-4.2.0-3.aix6.1.ppc.rpm

以上的包都可以在IBM官網上下載到:

安裝這些包對/opt目錄有512MB的空間要求。

4 安裝unixODBC(root使用者)
#cd /opt/odbc/
#tar xvf unixODBC-2.3.0.tar.gz
#cd /opt/odbc/unixODBC-2.3.0
#./configure --enable-gui=no --enable-drivers=no
#make
#make install
(預設是被安裝到/usr/local)

5 安裝Oracle ODBC(root使用者)
#cd /opt/odbc/
#unzip basic-10.2.0.4.0-aix-ppc32.zip
#unzip odbc-10.2.0.4.0-aix-ppc32.zip
(兩個檔案解壓到同一個目錄instantclient_10_2下)
#cd /opt/odbc/instantclient_10_2
#chmod 775 odbc_update_ini.sh
#./odbc_update_ini.sh /usr/local
(沒有提示表示安裝成功)

odbc_update_ini.sh引數說明:
引數1:unixODBC DM安裝路徑。
引數2:驅動安裝的絕對路徑(可選)。預設為執行指令碼的路徑。
引數3:驅動名(可選),預設為Oracle 10g ODBC driver。
引數4:資料來源名稱(可選),預設為OracleODBC-10g。
執行完成後將新增一個DNS條目到$HOME/.odbc.ini , /etc/odbcinst.ini,名稱為:OracleODBC-10g

修改odbc目錄的許可權:
chown –R 775 /opt/odbc

6 配置本地服務名(oracle使用者)
新增本地服務名。
$TNS_ADMIN/tnsnames.ora

$ORACLE_HOME/network/admin/tnsnames.ora
例如:
TEST =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = test)
    )
  )
如果是非Oracle使用者,可以透過設定環境變數TNS_ADMIN來制定tnsnames.ora所在位置,當該改使用者有對tnsnames.ora讀的許可權。


7 檢查驅動配置(root使用者)

/usr/local/etc/odbcinst.ini
[Oracle 10g ODBC driver]
Description     = Oracle ODBC driver for Oracle 10g
Driver          = /opt/odbc/instantclient_10_2/libsqora.so
Setup           =
FileUsage       =
CPTimeout       =
CPReuse         =

這裡我們要手動修改驅動,將libsqora.so.10.1修改為libsqora.so

8 新增oracle odbc配置(oracle使用者)
vi ~/.odbc.ini
[OracleODBC-10g]
Application Attributes = T
Attributes = W
BatchAutocommitMode = IfAllSuccessful
BindAsFLOAT = F
CloseCursor = F
DisableDPM = F
DisableMTS = T
Driver = Oracle 10g ODBC driver       #對應/usr/local/etc/odbcinst.ini中的驅動配置名稱
DSN = OracleODBC-10g
EXECSchemaOpt =
EXECSyntax = T
Failover = T
FailoverDelay = 10
FailoverRetryCount = 10
FetchBufferSize = 64000
ForceWCHAR = F
Lobs = T
Longs = T
MetadataIdDefault = F
QueryTimeout = T
ResultSets = T
ServerName =test      #對應tnsnames.ora中配置的本地服務名
SQLGetData extensions = F
Translation DLL =
Translation ption = 0
DisableRULEHint = T
UserID =

9 設定環境變數(oracle使用者)
export LIBPATH=$LD_LIBRARY_PATH:/opt/odbc/instantclient_10_2:/usr/local/lib
export PATH=$PATH:/usr/local/bin
TNS_ADMIN(如果安裝有oracle軟體那麼對應的就是$ORACLE_HOME/network/admin/目錄,如果沒有安裝相應oracle軟體,需要指定tnsnames.ora所在的目錄,可選)
NLS_LANG(設定合適的字符集,可選)

10 測試(oracle使用者)
./isql OracleODBC-10g store store -v
+---------------------------------------+
| Connected!                            |
|                                       |
| sql-statement                         |
| help [tablename]                      |
| quit                                  |
|                                       |
+---------------------------------------+
SQL> select * from v$version;
+-----------------------------------------------------------------+
| BANNER                                                          |
+-----------------------------------------------------------------+
| Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod|
| PL/SQL Release 10.2.0.1.0 - Production                          |
| CORE  10.2.0.1.0      Production                                      |
| TNS for 32-bit Windows: Version 10.2.0.1.0 - Production         |
| NLSRTL Version 10.2.0.1.0 - Production                          |
+-----------------------------------------------------------------+
SQLRowCount returns -1
5 rows fetched

isql -v

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23135684/viewspace-667160/,如需轉載,請註明出處,否則將追究法律責任。

相關文章