有关代码片段的说明

时间:2009-10-09 10:51:47

标签: sql c informix

我在通过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 */
}

2 个答案:

答案 0 :(得分:1)

我相信它是从名为refer_num的数据库序列中获取下一个值。序列是一种为数字唯一标识符生成值的方法 - 有点像某些DBMS中的IDENTITY列。我不知道Informix,但我的猜测是“table(SET {''})”是一种生成一行伪表的方法,这样你就可以执行一个实际上不需要访问的select语句任何真正的数据库表。为此,Oracle有一个名为DUAL的特殊表,这在Oracle中很常见:

select refer_num.nextval from dual;

答案 1 :(得分:-1)

用于获取Informix中序列生成器的下一个值:

your_seq_generator_name.nextval

中选择table(set{1});