機械翻訳について

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

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

B.1 サポート対象のSQL文

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

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

関連項目:

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

B.1.1 DELETE

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

関連項目:

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

B.1.2 INSERT

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

関連項目:

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

B.1.3 SELECT

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

  • CONNECT BY condition

  • NOWAIT

  • START WITH condition

  • HAVING句のサブ問合せ

B.1.4 UPDATE

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

関連項目:

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

B.2 Oracle関数

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

B.2.1 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

B.2.2 Informixでサポートされる関数

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

B.2.2.1 算術演算子
Oracle Informix

+

+

-

-

*

*

/

/

B.2.2.2 比較演算子
Oracle Informix

=

=

>

>

<

<

>=

>=

<=

<=

<>, !=, ^=

<>

IS NOT NULL

IS NOT NULL

IS NULL

IS NULL

B.2.2.3 グループ機能
Oracle Informix

AVG

AVG

COUNT

COUNT

MAX

MAX

MIN

MIN

SUM

SUM

B.2.2.4 文字列関数
Oracle Informix

||CONCAT

||

ASCII

ASCII

CHR

CHR

LENGTH

LENGTH

B.2.2.5 パターン・マッチ
Oracle Informix

LIKE 'a%'

LIKE "a%"

LIKE 'a_'

LIKE "a_"

LIKE 'a\%' ESCAPE '\'

LIKE "a\%" ESCAPE ""

NOT LIKE

NOT LIKE

B.2.2.6 日付関数
Oracle Informix

date + number

date + number

date - number

date - number

date + date

date + date

date - date

date - date

B.2.2.7 その他の機能
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

B.2.3 ゲートウェイでサポートされる関数

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データ型のパラメータに変換されます。