Informix脚本中的局部变量

时间:2011-05-23 13:40:20

标签: informix

我必须做一个大的更新脚本 - 而不是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会在定义行上窒息。

有没有办法在不必将其创建为存储过程的情况下执行此操作,运行一次然后删除该过程?

2 个答案:

答案 0 :(得分:2)

如果所涉及的表中的列数与您的示例相同,那么您可以使SPL成为永久性的,并使用它来插入数据,即:

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

显然,这种做法并不是很好,但对你的例子来说还可以。

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

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 (...);

答案 1 :(得分:0)

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()。