機械翻訳について

B サポートされているSQL構文と関数

次のトピックでは、サポートされているSQLの構文と関数について説明します:

サポート対象のSQL文

いくつかの例外はあるものの、ゲートウェイではOracleのDELETE文、INSERT文、SELECT文およびUPDATE文が完全サポートされています。

ゲートウェイでは、Oracleデータ定義言語(DDL)文はサポートされていません。 OracleのALTER文、CREATE文、DROP文、GRANT文またはTRUNCATE文の形式は一切使用できません。 代わりに、Informixデータベースに対してDDL文を使用する必要がある場合は、ゲートウェイのパススルー機能を使用してください。

関連項目:

キーワード、パラメータおよびオプションの詳細な説明は、『Oracle Database SQL言語リファレンス』を参照してください。

DELETE

DELETE文は完全サポートされています ただし、InformixでサポートされているOracle機能のみを使用できます。 また、外側の問合せで同じ表名を参照するSQL文をサブ問合せで使用することはできません。

関連項目:

「"Informixでサポートされる関数"」はサポートされている関数のリストです。

INSERT

INSERT文は完全サポートされています。 ただし、InformixでサポートされているOracle機能のみを使用できます。 また、外側の問合せで同じ表名を参照するSQL文をサブ問合せで使用することはできません。

関連項目:

「"Informixでサポートされる関数"」はサポートされている関数のリストです。

SELECT

SELECT文は完全サポートされています。ただし、次の例外があります。

  • CONNECT BY condition

  • NOWAIT

  • START WITH condition

  • HAVING句のサブ問合せ

UPDATE

UPDATE文は完全サポートされています。 ただし、InformixでサポートされているOracle機能のみを使用できます。 また、外側の問合せで同じ表名を参照するSQL文をサブ問合せで使用することはできません。 サブ問合せはSET句ではサポートされていません。 InformixはUPDATEの表別名をサポートしていません。

関連項目:

「"Informixでサポートされる関数"」はサポートされている関数のリストです。

Oracle関数

すべての機能は、ゲートウェイがInformix SQLに変換した後、Informixデータベースによって評価されます。

Informixでサポートされていない関数

Informixで同等の機能を持たないOracle SQL関数は、 DELETE INSERT、または UPDATE文ではサポートされていませんが、文がSELECT文の場合はOracleデータベースによって評価されます。 つまり、Oracleデータベースは、ゲートウェイに送信されたSELECT文の後処理を実行します。

サポートされていない関数がDELETEINSERT、またはUPDATE文で使用されている場合、次のOracleエラーが発生します:

ORA-02070: database db_link_name does not support function in this context

Informixでサポートされる関数

ゲートウェイは、SQL文中の次のOracleデータベース関数を、同等のInformix関数に変換します:

算術演算子
Oracle Informix

+

+

-

-

*

*

/

/

比較演算子
Oracle Informix

=

=

>

>

<

<

>=

>=

<=

<=

<>, !=, ^=

<>

IS NOT NULL

IS NOT NULL

IS NULL

IS NULL

グループ関数
Oracle Informix

AVG

AVG

COUNT

COUNT

MAX

MAX

MIN

MIN

SUM

SUM

文字列関数
Oracle Informix

||CONCAT

||

ASCII

ASCII

CHR

CHR

LENGTH

LENGTH

パターン一致
Oracle Informix

LIKE 'a%'

LIKE "a%"

LIKE 'a_'

LIKE "a_"

LIKE 'a\%' ESCAPE '\'

LIKE "a\%" ESCAPE ""

NOT LIKE

NOT LIKE

日付関数
Oracle Informix

date + number

date + number

date - number

date - number

date + date

date + date

date - date

date - date

その他の関数
Oracle Informix

ABS

ABS

COS

COS

EXP

EXP

LOG10

LOG10

LN

LOGN

LTRIM(char)

TRIM(LEADING FROM char)

MOD

MOD

POWER (m,n)

POW(m,n)

RTRIM(char)

TRIM(TRAILING FROM char)

ROUND (1引数付き)

ROUND

SIN

SIN

SQRT

SQRT

TAN

TAN

TRUNC (1引数付き)

TRUNC

ゲートウェイがサポートする機能

Oracle関数にInformixで同等の機能がない場合、Oracle関数はSQL文に変換されず、SQL文がSELECTの場合は後処理する必要があります。

しかし、Informixには同等の機能がないのに、ゲートウェイは1つの機能をサポートしています。 この関数はTO_DATE関数です:

TO_DATE(date_string | date_column)

説明:

date_stringは、次の形式の文字列に変換されます:

yyyy-mm-dd hh:mi:ss.fff

注意:

結果と同じ形式(つまり、yyyy-mm-dd hh:mi:ss.fff)の日付文字列を指定します。

date_columnは日付データ型の列です。 これは、timestampデータ型のパラメータに変換されます。