2 SQL Serverゲートウェイの機能と制限
ゲートウェイをインストールして構成したら、ゲートウェイを使用してSQL Serverデータにアクセスしたり、アプリケーションからSQL ServerデータベースにSQL Serverコマンドを渡したり、分散問合せを実行したり、データをコピーしたりできます。
トピック:
リモート挿入Rowsource
リモート挿入行ソース機能を使用すると、ローカルOracleデータをOracleデータベースおよびOracle Databaseゲートウェイで処理する必要があるリモート挿入が可能になります。 この機能を使用するには、OracleデータベースとOracle Databaseゲートウェイをバージョン12.2以降にする必要があります。
Oracle Databaseデザインでは、データベース・リンク・サイトで分散文を実行する必要があります。 しかし、特定の状況では、これらの問合せを実行するために必要なデータがあります。このデータは、元のOracle Databaseからフェッチする必要があります。 同種の接続では、リモートOracleデータベースは、そのようなデータのソースOracleデータベースをコールバックします。 しかし、異種の接続では、これは実行可能ではありません。これは、外部データストアが、問合せを発行したOracleインスタンスによってのみ提供できるコールバック関数またはデータを問合せする必要があることを意味するためです。 一般的に、これらの種類の文は、Oracle Databaseゲートウェイでサポートできるものではありません。
次のカテゴリのSQL文では、コールバックが発生します:
-
Oracleデータベース内の表を参照するサブ選択付きDML。
-
DELETE
、INSERT
、UPDATE
または"SELECT... FOR UPDATE...
"元のOracleデータベースで実行する必要があるSQL関数または文を含むSQL文。これらのSQL関数には、
USER
、USERENV
、およびSYSDATE
が含まれます。元のOracleデータベースからのデータの選択を伴います。 -
Oracleデータベース内の表を含むSQL文、およびリモート表の
LONG
またはLOB
列。
リモート挿入rowsource機能を使用して動作するリモートINSERT
の例を次に示します:
INSERT INTO gateway_table@gateway_link select * from local_table;
パススルー機能の使用
ゲートウェイは、DBMS_HS_PASSTHROUGH
パッケージを使用して、SQL Serverコマンドまたは文をアプリケーションからSQL Serverデータベースに渡すことができます。
PL/SQLブロックでDBMS_HS_PASSTHROUGH
パッケージを使用して、次のようにSQL Serverデータベースに渡す文を指定します:
DECLARE
num_rows INTEGER;
BEGIN
num_rows := DBMS_HS_PASSTHROUGH.EXECUTE_IMMEDIATE@MSQL('command');
END;
/
commandには、次のいずれも使用できません。
-
BEGIN
TRANSACTION
-
COMMIT
-
ROLLBACK
-
SAVE
-
SHUTDOWN
-
RELEASE
-
SAVEPOINT
-
CONNECT
-
SQL Serverツール・コマンド
DBMS_HS_PASSTHROUGH
パッケージでは、バインド値を渡すこと、およびSELECT文を実行することがサポートされています。
注意:
TRUNCATEはパススルー文では使用できません。
関連項目:
DBMS_HS_PASSTHROUGH
パッケージの詳細については、「Oracle Database異機種間接続ユーザーズ・ガイド」の「Oracle Database PL/SQLパッケージと型リファレンス」および第3章、「Oracle Databaseゲートウェイの機能」を参照してください。
ストアド・プロシージャおよびストアド・ファンクションの実行
プロシージャ機能を使用すると、ゲートウェイはSQL Serverデータベースで定義されているストアド・プロシージャを実行できます。 ゲートウェイを再リンクするか、またはプロシージャをゲートウェイに定義する必要はありませんが、プロシージャのアクセス特権は、ゲートウェイがログインしているユーザーによるアクセスを許可する必要があります。
ストアド・プロシージャの実行には、標準のPL/SQL文が使用されます。
ゲートウェイは、相互に排他的な3つのモードでストアド・プロシージャをサポートします:
-
ノーマル・モード:
IN
/OUT
引数のみにアクセスできます -
戻り値モード: すべてのストアド・プロシージャの戻り値を持つ
-
結果セット・モード: アウト値は最後の結果セットとして使用可能です
CHARセマンティクス
この機能により、ゲートウェイはオプションでCHAR
セマンティクス・モードで実行できます。 SQL ServerのCHAR
列をCHAR(n BYTE)
として記述するのではなく、CHAR(n CHAR)
およびVARCHAR(n CHAR)
として記述します。 この概念は、OracleデータベースのCHAR
セマンティクスに似ています。 このオプションをアクティブにするには、HS_NLS_LENGTH_SEMANTICS=CHAR
ゲートウェイ・パラメータを指定する必要があります。 詳細は「初期化パラメータ」を参照してください。
マルチバイト文字セット比率抑制
この機能は、オプションでマルチバイト文字セットを含むSQL ServerデータベースからOracleデータベースへの比率の拡張を抑制します。 デフォルトでは、Oracleゲートウェイは、データが切り捨てられたり、バッファ・サイズが不十分な状態にならないように、最悪の比率を想定しています。 ただし、SQL Serverデータベースに関する特定の知識があり、展開が発生しないようにするには、HS_KEEP_REMOTE_COLUMN_SIZE
パラメータを指定して展開を抑制します。 詳細は「初期化パラメータ」を参照してください。
IPv6のサポート
Oracleデータベースとゲートウェイ間の完全なIPv6サポートに加えて、IPv6はこのゲートウェイとSQL Serverデータベース間でもサポートされています。 詳細は、「初期化パラメータ」のHS_FDS_CONNECT_INFO
パラメータを参照してください。
ゲートウェイ・セッションIDLEタイムアウト
必要に応じて、ゲートウェイ・パラメータHS_IDLE_TIMEOUT
を使用して、長いアイドル・ゲートウェイ・セッションを自動的に終了することもできます。 具体的には、ゲートウェイ・セッションが指定された制限時間を超えてアイドル状態になると、保留中の更新がロールバックされてゲートウェイ・セッションが終了します。 詳細については、「初期化パラメータ」のHS_IDLE_TIMEOUT
パラメータを参照してください。
リモート・ユーザー定義関数のサポート
Oracle以外のリモート・データベースのユーザー定義関数は、SQL文で使用できます。
関連項目:
Oracle以外のデータベースでユーザー定義関数を実行する方法の詳細は、「Oracle Database異機種間接続ユーザーズ・ガイド」を参照してください。
戻り値とストアド・プロシージャ
デフォルトでは、すべてのストアド・プロシージャおよび関数は、ユーザーに戻り値を返しません。 戻り値を有効にするには、HS_FDS_PROC_IS_FUNC
パラメータの値をTRUE
に設定します。
関連項目:
初期化パラメータ・ファイルとHS_FDS_PROC_IS_FUNC
パラメータの編集に関する情報は、「初期化パラメータ」を参照してください。
注意:
HS_FDS_PROC_IS_FUNC
ゲートウェイ初期化パラメータをTRUE
に設定する場合は、既存のすべてのストアド・プロシージャのプロシージャexecute文の構文を変更する必要があります。
次の例では、従業員名JOHN SMYTHE
がSQL Serverストアド・プロシージャREVISE_SALARY
に渡されます。 ストアド・プロシージャは、SQL Serverデータベースから給与額を取得して、JOHN SMYTHE
の新しい年俸を計算します。 RESULT
で戻された改定給与は、Oracleデータベースの表のEMP
を更新するために使用されます:
DECLARE INPUT VARCHAR2(15); RESULT NUMBER(8,2); BEGIN INPUT := 'JOHN SMYTHE'; RESULT := REVISE_SALARY@MSQL(INPUT); UPDATE EMP SET SAL = RESULT WHERE ENAME =: INPUT; END; /
プロシージャ機能により、Oracle以外のデータ型とPL/SQLデータ型との間の変換は自動的に行われます。
結果セットとストアド・プロシージャ
Oracle Database Gateway for SQL Serverは、結果セットを返すストアド・プロシージャをサポートしています。
デフォルトでは、すべてのストアド・プロシージャおよび関数は、ユーザーに結果セットを返しません。 結果セットを使用可能にするには、HS_FDS_RESULTSET_SUPPORT
パラメータ値をTRUE
に設定します。
関連項目:
初期化パラメータ・ファイルとHS_FDS_RESULTSET_SUPPORT
パラメータの編集に関する情報は、「初期化パラメータ」を参照してください。 Oracle以外のデータベースの結果セットに対するOracleサポートの詳細は、「Oracle Database異機種間接続ユーザーズ・ガイド」を参照してください。
注意:
HS_FDS_RESULTSET_SUPPORT
ゲートウェイ初期化パラメータをTRUE
に設定した場合は、既存のすべてのストアド・プロシージャのプロシージャ文の構文を変更する必要があります。そうでないとエラーが発生します。
Oracle Database Gateway for SQL Serverを使用して結果セットを含むストアド・プロシージャにアクセスすると、異機種間サービスの順次モードになります。
Oracle Database Gateway for SQL Serverは、プロシージャの説明中に異機種間サービスに以下の情報を戻します:
-
リモート・ストアド・プロシージャのすべての入力引数
-
出力引数はなし
-
REF CURSOR型の1つの出力引数(ストアド・プロシージャにより返された最初の結果セットに対応)
クライアント・プログラムは、仮想パッケージ関数DBMS_HS_RESULT_SET.GET_NEXT_RESULT_SET
を使用して、後続の結果セットの参照カーソルを取得する必要があります。 返された最後の結果セットは、プロシージャの出力引数です。
結果セットへのアクセスには次の制限事項があります。
-
リモート・ストアド・プロシージャにより返された結果セットは、送信された順序で取り出す必要があります。
-
ストアド・プロシージャの実行時に、すでに実行されたストアド・プロシージャにより返された結果セットはすべて(データが完全に取り出されたかどうかに関係なく)クローズされます。
次の例では、SQL Serverストアド・プロシージャを実行して、SQL Serverからemp
およびdept
表の内容をフェッチします:
create procedure REFCURPROC (@arg1 varchar(255), @arg2 varchar(255) output) as select @arg2 = @arg1 select * from EMP select * from DEPT go
このストアド・プロシージャでは、出力パラメータarg2に入力パラメータarg1を割り当て、参照カーソルrc1で問合せSELECT * FROM EMP
をオープンし、参照カーソルrc2で問合せSELECT * FROM DEPT
をオープンしています。
シーケンシャル・モードでのOCIプログラムによる結果セットからのフェッチ
次の例では、シーケンシャル・モードでのOCIプログラムによる結果セットからのフェッチを示します。
OCIEnv *ENVH; OCISvcCtx *SVCH; OCIStmt *STMH; OCIError *ERRH; OCIBind *BNDH[3]; OraText arg1[20]; OraText arg2[255]; OCIResult *rset; OCIStmt *rstmt; ub2 rcode[3]; ub2 rlens[3]; sb2 inds[3]; OraText *stmt = (OraText *) "begin refcurproc@MSQL(:1,:2,:3); end;"; OraText *n_rs_stm = (OraText *) "begin :ret := DBMS_HS_RESULT_SET.GET_NEXT_RESULT_SET@MSQL; end;"; /* Prepare procedure call statement */ /* Handle Initialization code skipped */ OCIStmtPrepare(STMH, ERRH, stmt, strlen(stmt), OCI_NTV_SYNTAX, OCI_DEFAULT); /* Bind procedure arguments */ inds[0] = 0; strcpy((char *) arg1, "Hello World"); rlens[0] = strlen(arg1); OCIBindByPos(STMH, &BNDH[0], ERRH, 1, (dvoid *) arg1, 20, SQLT_CHR, (dvoid *) &(inds[0]), &(rlens[0]), &(rcode[0]), 0, (ub4 *) 0, OCI_DEFAULT); inds[1] = -1; OCIBindByPos(STMH, &BNDH[1], ERRH, 1, (dvoid *) arg2, 20, SQLT_CHR, (dvoid *) &(inds[1]), &(rlens[1]), &(rcode[1]), 0, (ub4 *) 0, OCI_DEFAULT); inds[2] = 0; rlens[2] = 0; OCIDescriptorAlloc(ENVH, (dvoid **) &rset, OCI_DTYPE_RSET, 0, (dvoid **) 0); OCIBindByPos(STMH, &BNDH[2], ERRH, 2, (dvoid *) rset, 0, SQLT_RSET, (dvoid *) &(inds[2]), &(rlens[2]), &(rcode[2]), 0, (ub4 *) 0, OCI_DEFAULT); /* Execute procedure */ OCIStmtExecute(SVCH, STMH, ERRH, 1, 0, (CONST OCISnapshot *) 0, (OCISnapshot *) 0, OCI_DEFAULT); /* Convert result set to statement handle */ OCIResultSetToStmt(rset, ERRH); rstmt = (OCIStmt *) rset; /* After this the user can fetch from rstmt */ /* Issue get_next_result_set call to get handle to next_result set */ /* Prepare Get next result set procedure call */ OCIStmtPrepare(STMH, ERRH, n_rs_stm, strlen(n_rs_stm), OCI_NTV_SYNTAX, OCI_DEFAULT); /* Bind return value */ OCIBindByPos(STMH, &BNDH[1], ERRH, 1, (dvoid *) rset, 0, SQLT_RSET, (dvoid *) &(inds[1]), &(rlens[1]), &(rcode[1]), 0, (ub4 *) 0, OCI_DEFAULT); /* Execute statement to get next result set*/ OCIStmtExecute(SVCH, STMH, ERRH, 1, 0, (CONST OCISnapshot *) 0, (OCISnapshot *) 0, OCI_DEFAULT); /* Convert next result set to statement handle */ OCIResultSetToStmt(rset, ERRH); rstmt = (OCIStmt *) rset; /* Now rstmt will point to the second result set returned by the remote stored procedure */ /* Repeat execution of get_next_result_set to get the output arguments */
シーケンシャル・モードでのPL/SQLプログラムによる結果セットからのフェッチ
表loc_emp
は、SQL Serverのemp
表とまったく同じローカル表であるとします。 同じ仮定がloc_dept
に適用されます。 表outargs
には、SQL Serverストアド・プロシージャのout
引数に対応する列があります。
create table outargs (outarg varchar2(255), retval number);
create or replace package rcpackage is type RCTYPE is ref cursor; end rcpackage; /
declare rc1 rcpackage.rctype; rec1 loc_emp%rowtype; rc2 rcpackage.rctype; rec2 loc_dept%rowtype; rc3 rcpackage.rctype; rec3 outargs%rowtype; out_arg varchar2(255); begin -- Execute procedure out_arg := null; refcurproc@MSQL('Hello World', out_arg, rc1); -- Fetch 20 rows from the remote emp table and insert them into loc_emp for i in 1 .. 20 loop fetch rc1 into rec1; insert into loc_emp (rec1.empno, rec1.ename, rec1.job, rec1.mgr, rec1.hiredate, rec1.sal, rec1.comm, rec1.deptno); end loop; -- Close ref cursor close rc1; -- Get the next result set returned by the stored procedure rc2 := dbms_hs_result_set.get_next_result_set@MSQL; -- Fetch 5 rows from the remote dept table and insert them into loc_dept for i in 1 .. 5 loop fetch rc2 into rec2; insert into loc_dept values (rec2.deptno, rec2.dname, rec2.loc); end loop; --Close ref cursor close rc2; -- Get the output arguments from the remote stored procedure -- Since we are in sequential mode, they will be returned in the -- form of a result set rc3 := dbms_hs_result_set.get_next_result_set@MSQL; -- Fetch them and insert them into the outargs table fetch rc3 into rec3; insert into outargs (rec3.outarg, rec3.retval); -- Close ref cursor close rc3; end; /
SQL Serverのデータベース互換性の問題
一部の領域でSQL ServerとOracleデータベースの機能が異なるため、互換性の問題が発生します。 互換性の問題については、次のリンクで説明しています:
命名規則
ネーミング規則の問題は次のとおりです。
オブジェクトのネーミング規則
OracleとSQL Serverでは、異なるデータベース・オブジェクト命名規則が使用されます。 たとえば、各オブジェクト名に認められている最大文字数が違います。 また、一重引用符および二重引用符の使用、大/小文字の区別、英数字の使用もすべて異なります。
関連項目:
「Oracle Databaseリファレンス」とSQL Serverのドキュメントを参照してください。
大/小文字区別
識別子を二重引用符で囲まない限り、Oracleデータベースのデフォルトは大文字になります。 たとえば、emp
という名前の「SQL Server」表を参照するには、次のように二重引用符で名前を入力します:
SQL> SELECT * FROM "emp"@MSQL;
ただし、OracleアプリケーションからScottが所有するemp
という「SQL Server」表を参照するには、次のように入力します:
SQL> SELECT * FROM "Scott"."emp"@MSQL;
emp
という名前の「SQL Server」表がSCOTT
によって所有されている場合、表所有者の名前は大文字で、次のように二重引用符を付けないで所有者名を入力できます:
SQL> SELECT * FROM SCOTT."emp"@MSQL;
または
SQL> SELECT * FROM scott."emp"@MSQL;
すべてのSQL Serverオブジェクト名を二重引用符で囲み、SQL Serverデータ・ディクショナリに表示されるオブジェクト名には大文字と小文字を使用することをお薦めします。 この規則は、サポートされているOracleデータ・ディクショナリ表または「データ辞書」にリストされているビューを参照する場合には必要ありません。
これらの規則に従って既存のアプリケーションを変更できない場合は、Oracleでビューを作成して、SQL Serverの名前を正しい大文字とするようにします。 たとえば、大文字のみを使用して既存のOracleアプリケーションから「SQL Server」表emp
を参照するには、次のビューを定義します:
SQL> CREATE VIEW EMP (EMPNO, ENAME, SAL, HIREDATE) AS SELECT "empno", "ename", "sal", "hiredate" FROM "emp"@MSQL;
このビューを使用して、アプリケーションは次のような文を発行できます。
SQL> SELECT EMPNO, ENAME FROM EMP;
ビューの使用は、SQL Serverのデータ・ディクショナリで生成されたデータ・ディクショナリ情報を複製する回避策です。 SQL Serverデータベースで対応する表のデータ定義が変更されると、Oracleビュー定義を更新する準備が必要です。
データ型
データ型の問題は次のとおりです。
バイナリのリテラル表記
Oracle SQLは、単一引用符で囲まれた16進数を使用して、データ型RAW
として定義された列に比較または挿入されるリテラル値を表します。
この表記は、SQL ServerのVARBINARY
およびBINARY
データ型(0x
の後ろに16進数を1つの引用符で囲む)と互換性のある構文に変換されません。
たとえば、次の文はサポートされていません。
SQL> INSERT INTO BINARY_TAB@MSQL VALUES ('0xff')
BINARY_TAB
には、データ型VARBINARY
またはBINARY
の列が含まれています。 VARBINARY
およびBINARY
データ型を挿入または更新する場合は、バインド変数を使用します。
データ型変換
SQL Serverは暗黙的な日付変換をサポートしていません。 このような変換は明示的にする必要があります。
たとえば、ゲートウェイは次のSELECT
文にエラーを発行します:
SELECT DATE_COL FROM TEST@MSQL WHERE DATE_COL = "1-JAN-2004";
暗黙的変換の問題を回避するには、次のように明示的変換を追加します。
SELECT DATE_COL FROM TEST@MSQL WHERE DATE_COL = TO_DATE("1-JAN-2004")
関連項目:
データ型に関する制限事項の詳細は、「データ型変換」を参照してください。
問合せ
行の選択
SQL Serverは、すべての行を返す前に、選択したすべての行の問合せ条件を評価します。 1行以上について評価処理でエラーが発生すると、残りの行が条件を満たしていても行は一切返されません。
Oracleでは、1行ずつ問合せ条件を評価し、評価処理でエラーが発生しなければ行を返します。 行の評価処理でエラーが発生するまで、行は返されます。
空の文字列
Oracleでは、SQL文の空の文字列をNULL値として処理します。 SQL Serverは、空の文字列を空の文字列として処理します。
空の文字列を比較すると、ゲートウェイは変換せずに文字通り空の文字列をSQL Serverデータベースに渡します。 空の文字列がNULL値を表すことを意図していた場合、SQL Serverはそのように文を処理しません。それは空の文字列を使用します。
次の例のように、空の文字列構文ではなく、SQL文でNULL
またはIS NULL
を使用することで、この問題を回避できます:
SELECT * from "emp"@MSQL where "ename" IS NULL;
空の文字列を選択するには:
-
VARCHAR
列の場合、ゲートウェイは空の文字列をOracleデータベースにNULL
の値として返します。 -
CHAR
列の場合、ゲートウェイは各文字を空白( '')として列のフル・サイズを戻します。
既知の制限事項
この項または既知の問題点で示されていない非互換性の問題が発生した場合は、Oracleサポート・サービスに連絡してください。 この項では、次の既知の制限事項について説明し、可能な場合はそれらに対処するための提案を示します。
注意:
制限事項については、Oracleサポート・サービスに問い合せてください。
複数のオープン文
SQL Serverへのアクセスには、各接続に対して1つのオープン文またはカーソルが許可されているという制限があります。 SQL Serverにアクセスする同じトランザクションで、2つ目の文またはカーソルをオープンする必要がある場合、新しい接続が必要です。
この制限のため、同じトランザクション内の複数のオープンされた文またはカーソルは、SQL Serverへの異なる接続を使用するため、互いにロックできます。
この制限を回避するには、コミットの発行またはロジックの変更、あるいはその両方を行います。
トランザクションの整合性
次のような場合、ゲートウェイではトランザクションの整合性が保証されません。
-
ゲートウェイで処理される文により、ターゲット・データベースで暗黙的コミットが発生する場合
-
ターゲット・データベースが自動コミット・モードで動作するように構成されている場合
注意:
次のことをお薦めします。
-
特定の文を実行するとターゲット・データベースで暗黙的コミットが発生することがわかっている場合は、その文が独自のトランザクションで実行されるようにします。
-
ゲートウェイは、SQL Serverデータベースへの接続が確立されると、オート・コミット・モードをオフに設定します。
PL/SQLカーソル・ループのCOMMITまたはROLLBACKによるオープン・カーソルのクローズ
PL/SQLカーソル・ループで発行されたCOMMIT
またはROLLBACK
は、開いているすべてのカーソルを閉じます。これにより、次のエラーが発生する可能性があります:
ORA-1002: fetch out of sequence
このエラーを回避するには、COMMIT
またはROLLBACK
文をカーソル・ループの外に移動します。
ストアド・プロシージャ
Oracleトランザクション・マネージャまたはOracleのCOMMIT
またはROLLBACK
コマンドは、コミットまたはロールバックを埋め込んだストアド・プロシージャによって発行された変更を管理できません
Oracle Database Gateway for SQL Serverを使用して結果セットを含むストアド・プロシージャにアクセスする場合は、異機種間サービスの順次モードで作業する必要があります。
Oracle Database Gateway for SQL Serverを使用して複数の結果セットを持つストアド・プロシージャにアクセスする場合は、続行する前にすべての結果セットを読み込む必要があります。
ストアド・プロシージャの出力パラメータは、空の文字列に初期化する必要があります。
DDL文
SQL Serverでは、独自のトランザクションで実行されるDDL文が必要であり、特定のトランザクションで実行できるDDL文は1つだけです。
これらのDDL文をSQL Serverストアド・プロシージャで使用し、プロシージャ機能を使用してゲートウェイ経由でストアド・プロシージャを実行するか、パススルー機能を使用してゲートウェイ経由でDDL文を実行すると、エラー状態が発生する可能性があります。 これは、ゲートウェイのプロシージャ機能およびパススルー機能では、DDL文がそれぞれ異なるトランザクションで実行されることが保証できないためです。
次のSQL Server DDL文は、パススルー機能を使用して渡す場合、またはパススルー機能を含むSQL Serverストアド・プロシージャを実行する場合、エラー状態を引き起こす可能性があります:
-
ALTER DATABASE
-
CREATE DATABASE
-
CREATE INDEX
-
CREATE PROCEDURE
-
CREATE TABLE
-
CREATE VIEW
-
DISK INIT
-
DROP <
object
>
-
DUMP TRANSACTION
-
GRANT
-
LOAD DATABASE
-
LOAD TRANSACTION
-
RECONFIGURE
-
REVOKE
-
SELECT INTO
-
TRUNCATE TABLE
-
UPDATE STATISTICS
関連項目:
DDL文の詳細については、SQL Serverのドキュメントを参照してください。
SQL構文
関数
関数の使用には、次の制限事項があります。
-
サポートされていない関数は、
LONG
列を参照する文では使用できません。 -
SUBSTR
関数の第2パラメータとして負の数を使用すると、不正な結果が返されます。 これは、OracleSUBSTR
関数とそれに相当するSQL Serverの間の非互換性が原因です。
小文字の表名を使用するSQL*PlusのCOPYコマンド
小文字の表名は二重引用符で囲む必要があります。
次に例を示します。
copy from tkhouser/tkhouser@inst1 insert loc_tkhodept using select * from "tkhodept"@holink2;
既知の問題点
この項では、既知の問題点について説明し、可能な場合は問題を修正するための提案を示します。 問題についての疑問は、Oracleサポート・サービスに問い合せてください。 問題の最新リストはオンラインで入手可能です。 リストへのアクセス方法については、地域のOracleのオフィスに問い合せてください。
この項では、次の既知の問題点について説明します。
暗号化形式のログイン
Oracle9iデータベース(リリース9.2以前)では、Oracle初期化パラメータDBLINK_ENCRYPT_LOGIN
がサポートされていました。 このパラメータをTRUE
に設定すると、ログイン・ユーザーIDのパスワードはネットワーク経由で送信されません。
このパラメータがOracle9iデータベースで使用される初期化パラメータ・ファイルのTRUE
に設定されている場合、Oracle9iがゲートウェイと通信できるように、デフォルト設定のFALSE
に設定を変更する必要があります。
現在のリリースでは、DBLINK_ENCRYPT_LOGIN
初期化パラメータは廃止されているため、確認する必要はありません。
日付計算
次のSQL式は、ゲートウェイでは正しく機能しません。
date + number number + date date - number date1 - date2
前述の式を含む文は、変換せずにSQL Serverデータベースに送信されます。 SQL Serverはこれらの日付演算関数をサポートしていないため、文はエラーを返します。
SQL ServerのIMAGE、TEXTおよびNTEXTデータ型
IMAGE
、TEXT
、およびNTEXT
データ型を使用する場合、次の制限が適用されます:
-
サポートされていないSQL関数は、SQL Serverデータ型
IMAGE
、TEXT
、またはNTEXT
として定義された列にアクセスするSQL文では使用できません。 -
データが80文字を超える場合、SQL*Plusを使用してSQL Serverデータ型
IMAGE
、TEXT
、またはNTEXT
として定義された列からデータを選択することはできません。 Pro * CまたはOracle Call Interfaceを使用して、SQL Serverデータベース内のそのようなデータにアクセスすることをお薦めします。 -
IMAGE
、TEXT
、およびNTEXT
データはパススルー問合せで読み取ることはできません。 -
SQL文が
IMAGE
、TEXT
、またはNTEXT
列を含む表にアクセスしている場合、文は2つの独立した文としてSQL Serverに送信されます。IMAGE
、TEXT
またはNTEXT
列にアクセスするための1つの文、および元の文内の他の列の2番目の文。
ゲートウェイは、DBMS_SQL
パッケージのPL/SQL関数COLUMN_VALUE_LONG
をサポートしていません。
関連項目:
SQL構文の制限事項の詳細は、「サポートされているSQL構文と関数」を参照してください。
スキーマ名とPL/SQL
PL/SQLブロック内のSQL文にSQL Serverデータベース・オブジェクトのスキーマ名をプレフィクスとして指定しないと、次のエラー・メッセージが表示されます:
ORA-6550 PLS-201 Identifier table_name must be declared.
SQL文を変更して、オブジェクトのスキーマ名を含めます。