在oracle表单中使用PL / JSON 11g

时间:2015-08-12 16:22:02

标签: json plsql oracle11g oracleforms pljson

我尝试在Oracle 11g表单中使用PL/JSON

当我直接在数据库上运行以下代码(取自PL / JSON的示例文件ex1.sql)时,它可以正常工作。

declare
  obj json;
begin
  obj := json('{"a": true }');

  obj.print;
  --more complex json:
  obj := json('
{
  "a": null,
  "b": 12.243,
  "c": 2e-3,
  "d": [true, false, "abdc", [1,2,3]],
  "e": [3, {"e2":3}],
  "f": {
    "f2":true
  }
}');
  obj.print;
  obj.print(false); --compact way
end;
/

返回

{
  "a" : true
}
{
  "a" : null,
  "b" : 12.243,
  "c" : 0.002,
  "d" : [true, false, "abdc", [1, 2, 3]],
  "e" : [3, {
    "e2" : 3
  }],
  "f" : {
    "f2" : true
  }
}
{"a":null,"b":12.243,"c":0.002,"d":[true,false,"abdc",[1,2,3]],"e":[3,{"e2":3}],"f":{"f2":true}}

现在,我想使用相同的逻辑,但是直接在Oracle 11g表单中使用以下代码。

PROCEDURE Ex1_Test IS
  obj json;

begin
  obj := json('{"a": true }');

  :MyField1 := obj.to_char;
  --more complex json:
  obj := json('
{
  "a": null,
  "b": 12.243,
  "c": 2e-3,
  "d": [true, false, "abdc", [1,2,3]],
  "e": [3, {"e2":3}],
  "f": {
    "f2":true
  }
}');

  :MyField2 := obj.to_char;

  :MyField3 := obj.to_char(false); --compact way

end;

然后,我从第7行ORA-00600 : internal error code获得Oracle :MyField1 := obj.to_char;的通用内部错误。

我做错了什么?是不是我想做的事情不可能?

感谢您的帮助! :)

1 个答案:

答案 0 :(得分:1)

ORA-00600是Oracle针对“未处理的副作用”的代码,即错误。警报日志中应该有一些其他信息。标准的ORA-00600建议是联系Oracle支持。

如果您没有支持合同,您的选择将受到限制。 ORA-00600消息应在方括号中带有一个或多个参数,如此

 ORA-00600: internal error code, arguments: [17069], [55573516], [], [], [], [], [], []  

这些参数对于识别特定原因很有用(第一个数字通常表示Oracle错误号,记录或以其他方式)。你可以试试谷歌搜索。

至于你的具体情况,恐怕我们只能推测。对象方法JSON.TO_CHAR()调用PL / SQL包函数JSON_PRINTER。这可能是问题所在。表单PL / SQL与数据库PL / SQL共享语法,但它们是不同的引擎;你可能遇到过一个关于Forms PL / SQL如何与具有依赖关系的SQL类型一起工作的错误。