sql - 关于代码片段的解释

标签 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 */
}

最佳答案

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

select refer_num.nextval from dual;

关于sql - 关于代码片段的解释,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1543095/

相关文章:

sql - 需要有关优化 SQL select 语句的帮助

c - OPENSSL 如何存储和恢复 key 来加密和解密消息?

sql - 如何在informix数据库中搜索一列

node.js - 在 Node 10 中使用 ifxnjs 混淆安装错误

java - 如何使用 Hibernate 进行查询并对对象字段应用限制

javascript - SQL 更新使用 Datepicker.js 将日期重置为 0000-00-00

c++ - 我可以强制冲洗 CAN 总线 socket 吗

asp.net - 使用 Informix 进行 SqlBulkCopy

sql - 更新 SELECT 语句的结果

c - 在 Linux C 中交替同步两个进程