Oracle ProC 插入到值中 ( (选择 ..) )



Run Pro*C on Oracle 10g.

我希望在插入语句值子句中进行子查询。此 sql 查询是完全有效的,并且在 TOAD 中运行没有问题,但 Pro*C 无法解析查询。

EXEC SQL INSERT INTO TARGET_ATTACHMENT 
      (
          TARGET_ID
          FILENAME
      ) 
      VALUES ( 
         :targetID,
         ( SELECT CREATED_FLAG from TARGET t where t.TARGET_ID = :targetID ) || '.tif'
      )

如果我删除:

( SELECT (CREATED_FLAG || DISPLAY_ID) from TARGET t where t.TARGET_ID = :targetID ) ||**". 

Pro*C 编译器工作,一切都按预期编译和运行。

如果我不删除:Pro*C 编译器引发语法错误。

1>Syntax error at line 128, column 12, file        d:SVN...TA.pc:
1>Error at line 128, column 12 in file d:SVN...
1>...TA.pc
1>                ( select CREATED_FLAG from target t where t.TARGET_ID = :targetID )
1>...........1
1>PCC-S-02201, Encountered the symbol "CREATED_FLAG" when expecting one of the fol
1>lowing:
1>   ( ) * + - / . @ | at, day, hour, minute, month, second, year,

这是一个问题,因为我希望 Pro*C 能够在值 caluse 中编译子查询:

即。

INSERT into table1 (col1) values ( (select t2.singleCol from table2 t2 where t2.priKey = :priKey) )

这是 Pro*C 的预期行为吗?还是应该支持值子句中的子查询?

可能将子查询更改为:

( SELECT CREATED_FLAG || '.tif' from TARGET t where t.TARGET_ID = :targetID ) 

我想我从来没有见过像您尝试的那样附加到子查询的内容。

Pro*C 预处理器能够在静态 SQL 语句中解析的 SQL 数量非常有限。例如,它甚至无法解析显式inner joiner/outer left join等表示法。

作为一种解决方法,您可以准备一个动态 SQL 语句并执行它 - 即使您的 SQL 语句不是真正的动态。

您发布的代码在逻辑上与此相同:

INSERT INTO TARGET_ATTACHMENT       
  ( TARGET_ID ,  FILENAME )      
 select    :targetID, CREATED_FLAG|| '.tif' 
 from TARGET t 
where t.TARGET_ID = :targetID ) 
是否需要在

VALUES 子句中使用标量游标的特殊原因?

相关内容

  • 没有找到相关文章

最新更新