1

Cを介してInformixにアクセスするレガシーアプリケーションに次のコードフラグメントが表示されます。コード内のSQLが何を達成しようとしているのかを誰かが説明できますか?ありがとう。

EXEC SQL BEGIN DECLARE SECTION;
int i_tableref;
EXEC SQL END DECLARE SECTION;

    /* Some code here */

if (!i_sel_ref)
{
    exec sql begin declare section;
    const char *sql1 = 
        "select refer_num.nextval from table ( SET{''} )";
    exec sql end declare section;
    exec sql prepare oref_sel_fid from :sql1;
    if ( sqlca.sqlcode != SQL_OK )
    {
         /* some code */
    }
    /* More code */
}
4

2 に答える 2

1

私はそれがrefer_numと呼ばれるデータベースシーケンスから次の値を取得していると信じています。シーケンスは、数値の一意の識別子の値を生成する方法です。一部のDBMSのIDENTITY列に少し似ています。Informixはわかりませんが、「table(SET {''})」は、実際にアクセスする必要のないselectステートメントを実行できるように、1行の疑似テーブルを生成する方法だと思います。実際のデータベーステーブル。Oracleには、この目的のためにDUALと呼ばれる特別なテーブルがあり、これはOracleでよく見られることです。

select refer_num.nextval from dual;
于 2009-10-09T12:33:17.837 に答える
-1

Informixでシーケンスジェネレータの次の値を取得するため:

your_seq_generator_name.nextvalから選択table(set{1});

于 2017-06-27T06:03:18.453 に答える