タグ:oracle ( 2 ) タグの人気記事

Oracle Database Gateway for ODBC その2

Oracle Database Gateway for ODBC を少しいじってみた。
postgresqlのエントリを追加。

データ型のマッピング

SQLSERVER,Postgresqlとも
create table kkk
(
id int,
name varchar(20),
salary decimal(10,2)
)
で作成。これをORACLE側から見ると
DESC "dbo"."kkk"@mssql

id NUMBER(10)
name VARCHAR2(20)
salary NUMBER(10,2)

DESC "kkk"@postgresql

id NUMBER(10)
name VARCHAR(255)
salary NUMBER(10,2)

postgresqlの文字列型の表示がちょっとおかしい。これはpostgresqlのvarchar型がUTF-8対応
になっており文字数を表しているのにoracleはバイト数基準であるかららしい。
ちなみにpostgresqlで255桁指定まではORACLE側では255表示、それ以上はデータ型がLONG型表示になる。LONG型はoracleでは本来1テーブルに1フィールドしか指定できないが、この場合はoracle側で処理に制限を受けることはなさそう。あくまで見た目ということらしい。

データ操作(INSERT、DELETE、UPDATE)にはoracleの既定の動作と同様にトランザクションが有効になっている。

DELETE FROM "kkk"@postgresql;

と実行してもROLLBACKすればもとに復帰できる。
ただし、SELECT ... FOR UPDATE構文には対応していない。
また、INSERT INTO "kkk"@postgresql SELECT ... でORACLE側のテーブルのデータを一気に流し込むことはできないようだ。
逆にORACLE側に持ってくることはできる。

レスポンスもそんなに悪くはない。思ったよりも使える機能かもしれない。
[PR]
by nora1962 | 2009-09-17 01:00 | PC

Oracle Database Gateway for ODBC

Oracle Database Gateway for ODBCをoracle11gに設定してSqlserver2005と接続してみる。
設定するPCはVista Ultimate
あらかじめODBCのシステムDSN「mssql」を定義しておく。sqlserverの接続データベースはpubs。

(1)initXXX.oraファイルの編集
C:\app\nakagawa_takashi\product\11.1.0\db_1\hs\adminにinitmssql.oraを作成。中身は

HS_FDS_CONNECT_INFO = mssql

(2)listener.oraに以下のように編集

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = nora01)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = nora01)(PORT = 1522))

)
)
SID_LIST_LISTENER=
(SID_LIST=
(sid_desc=
(sid_name=mssql)
(ORACLE_HOME=C:\app\nakagawa_takashi\product\11.1.0\db_1)
(program=dg4odbc)
)
)

(3)tnsnames.oraに以下の内容を追加
mssql=
(description=
(address=(protocol=tcp)(host=nora01)(port=1522))
(connect_data=(sid=mssql))
(hs=ok)
)

ここでオラクル、オラクルリスナーを再起動。

sqlplusを立ち上げる。
(4)データベースリンク作成。接続ユーザーとパスワードは適宜。

create database link mssql connect to xxx idnetified by xxx using 'mssql';

(5)select文発行

select * from authors@mssql;

行1でエラーが発生しました。:
ORA-28500:
OracleからOracle以外のシステムへの接続で次のメッセージが戻されました:
[Microsoft][SQL Native
Client]他のコマンドの結果のために、接続がビジー状態になっています。
ORA-02063: 先行のエラー・メッセージを参照してください2 lines(MSSQL)。

いろいろ調べたり、試したりしたところスキーマを指定する必要があるみたい。

select * from dbo.authors@mssql;

ところが、

select au_id from dbo.authors@mssql;

だと

行1でエラーが発生しました。:
RA-00904: "AU_ID": 無効な識別子です

どうもカラム名はケースセンシティブなようだ。

select "au_id" from dbo.authors@mssql;

これで通った。

まずはここまで。
[PR]
by nora1962 | 2009-09-11 00:57 | PC