【问题标题】:Local variables in an Informix scriptInformix 脚本中的局部变量
【发布时间】:2011-05-23 13:40:20
【问题描述】:

我必须做一个大的更新脚本 - 而不是 SPL(存储过程)。 它是为 Informix 数据库编写的。

它涉及将行插入到多个表中,每个表都依赖于插入到前一个表中的序列。

我知道我可以通过这样做来访问连续剧:

SELECT DISTINCT dbinfo('sqlca.sqlerrd1') FROM systables

但我似乎无法在插入下一个表之前定义一个局部变量来存储它。

我想这样做:

insert into table1 (serial, data1, data2) values (0, 'newdata1', 'newdata2');
define serial1 as int;
let serial1 = SELECT DISTINCT dbinfo('sqlca.sqlerrd1') FROM systables;
insert into table2 (serial, data1, data2) values (0, serial1, 'newdata3');

当然,Informix 会在定义行阻塞。

有没有办法做到这一点,而不必将其创建为存储过程,运行一次然后删除该过程?

【问题讨论】:

    标签: informix


    【解决方案1】:

    如果涉及的表中的列数与您的示例一样少,那么您可以使 SPL 永久化,并使用它来插入您的数据,即:

    EXECUTE PROCEDURE insert_related_tables('newdata1','newdata2','newdata3');

    显然,这不能很好地扩展,但对于您的示例来说还可以。

    另一个扩展 Jonathan 示例并解决使用 MAX() 可能引起的任何并发问题的想法是在 Table3 中包含 DBINFO('sessionid')

    DELETE FROM Table3 WHERE sessionid = DBINFO('sessionid');
    INSERT INTO Table1 (...);
    INSERT INTO Table3 (sessionid, value)
      VALUES (DBINFO('sessionid'), DBINFO('sqlca.sqlerrd1'));
    INSERT INTO Table2 
      VALUES (0, (SELECT value FROM Table3
                  WHERE sessionid = DBINFO('sessionid'), 'newdata3');
    ...
    

    您还可以将 Table3 设为 TEMP 表:

    INSERT INTO Table1 (...);
    SELECT DISTINCT DBINFO('sqlca.sqlerrd1') AS serial_value
      FROM some_dummy_table_like_systables
    INTO TEMP Table3 WITH NO LOG;
    INSERT INTO Table2 (...);
    

    【讨论】:

    • 我在 Table3 中省略了一个 TEMP,这会导致并发问题;由于它是一个临时表,因此不存在并发问题,因为它只保存当前会话的值。到处都是用TEMP写的SQL,对去掉TEMP太热心了。不过,好点子。
    【解决方案2】:

    Informix 没有为您想要的类型的“局部变量”提供存储过程之外的机制。但是,在您提供的有限示例中,这是可行的:

    CREATE TABLE Table1
    (
        serial SERIAL(123) NOT NULL,
        data1  VARCHAR(32) NOT NULL,
        data2  VARCHAR(32) NOT NULL
    );
    CREATE TABLE Table2
    (
        serial SERIAL      NOT NULL,
        data1  INTEGER     NOT NULL,
        data2  VARCHAR(32) NOT NULL
    );
    
    INSERT INTO Table1(Serial, Data1, Data2)
        VALUES(0, 'newdata1', 'newdata2');
    INSERT INTO Table2(Serial, Data1, Data2)
        VALUES(0, DBINFO('sqlca.sqlerrd1'), 'newdata3');
    
    SELECT * FROM Table1;
    
    123   newdata1     newdata2
    
    SELECT * FROM Table2;
    
    1     123          newdata3
    

    但是,这只是因为您需要在 Table2 中插入一行。如果您需要插入更多,该技术将无法正常工作。我想你可以使用:

    CREATE TEMP TABLE Table3
    (
        value   INTEGER NOT NULL
    );
    
    INSERT INTO Table1(Serial, Data1, Data2)
        VALUES(0, 'newdata1', 'newdata2');
    INSERT INTO Table3(Value)
        VALUES(DBINFO('sqlca.sqlerrd1'));
    INSERT INTO Table2(Serial, Data1, Data2)
        VALUES(0, (SELECT MAX(value) FROM Table3), 'newdata3');
    INSERT INTO Table2(Serial, Data1, Data2)
        VALUES(0, (SELECT MAX(value) FROM Table3), 'newdata4');
    

    等等……Table3的临时表避免了并发和MAX()的问题。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2019-10-04
      • 2013-01-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-03-03
      相关资源
      最近更新 更多