Функция PL / SQL json_value выдает ошибку для большого документа JSON - PullRequest
1 голос
/ 04 октября 2019

Служба - это попытка извлечь ролид из объекта JSON, но она дает

Error report:
ORA-01460: unimplemented or unreasonable conversion requested
ORA-06512: at line 1801
01460. 00000 -  "unimplemented or unreasonable conversion requested"
*Cause:    
*Action:

Код:

set serveroutput on
declare
    input_data      VARCHAR2(32000);
    lv_role_id     VARCHAR2 (100);
begin
    input_data := '';
    input_data:=input_data||'{';
    input_data:=input_data||'  "roleid": "2945",';
    input_data:=input_data||'  "featureid": "3",';
    input_data:=input_data||'  "category": [';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "31",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "32",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "33",';
    input_data:=input_data||'      "ischecked": true';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "34",';
    input_data:=input_data||'      "ischecked": true';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "35",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "36",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "37",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "38",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "39",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "40",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "41",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "43",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "42",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "44",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "45",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "46",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "47",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "48",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "49",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "50",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "51",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "52",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "53",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "54",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "55",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "56",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "57",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "58",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "59",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "60",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "81",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "314",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "276",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "86",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "72",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "271",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "78",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "383",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "206",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "210",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "384",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "122",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "352",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "307",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "291",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "125",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "236",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "82",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "247",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "234",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "232",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "112",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "66",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "107",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "71",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "73",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "246",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "192",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "273",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "80",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "106",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "195",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "144",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "262",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "118",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "109",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "160",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "272",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "238",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "156",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "178",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "339",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    input_data:=input_data||'    {';
    input_data:=input_data||'      "featureid": "3",';
    input_data:=input_data||'      "id": "277",';
    input_data:=input_data||'      "ischecked": false';
    input_data:=input_data||'    },';
    // input_data:=much more data
    input_data:=input_data||'  ]';
    input_data:=input_data||'}';

    SELECT JSON_VALUE (input_data, '$.roleid' returning number) INTO lv_role_id FROM DUAL;

end;
/

Однако, несмотря на то, что другие могут подумать, размердокумент, кажется, имеет эффект. Если я запускаю следующий намного меньший анализ JSON, он анализирует значение.

set serveroutput on
declare
    input_data      VARCHAR2(32000);
    lv_role_id     VARCHAR2 (100);
begin
    input_data := '';
    input_data:=input_data||'{';
    input_data:=input_data||'  "roleid": "2945",';
    input_data:=input_data||'  "featureid": "3"';
    input_data:=input_data||'}';

    SELECT JSON_VALUE (input_data, '$.roleid' returning number) INTO lv_role_id FROM DUAL;

end;
/

Я попытался получить реальную полезную нагрузку JSON и запустить ее через валидатор lint, и даже длинный из них соответствует. Вставка JSON в CLOB в таблице, затем запуск SELECT JSON_VALUE для столбца работали. Парень из AskTom говорит, что проблема заключается в возврате большого значения, но я думаю, что проблема заключается в получении большого значения.

1 Ответ

2 голосов
/ 04 октября 2019

Кажется, у вашей версии БД есть проблема. Это не упоминается, поэтому я бы порекомендовал обновить или поискать патчи. Я сократил ваш пример, чтобы иметь цикл, который добавляет документ вместо этого для простоты тестирования. Это в db 19.3 и показывает, что json input_data имеет длину 31k и печатает ожидаемое сообщение.

$ sql klrice/klrice

SQLcl: Release 19.2 Production on Fri Oct 04 14:48:32 2019

Copyright (c) 1982, 2019, Oracle.  All rights reserved.

Last Successful login time: Fri Oct 04 2019 14:48:34 -04:00

Connected to:
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0

SQL> set serveroutput on
SQL>
SQL> declare
        input_data      VARCHAR2(32000);
        lv_role_id     VARCHAR2 (100);
    begin
        input_data := '';
        input_data:=input_data||'{';
        input_data:=input_data||'  "roleid": "2945",';
        input_data:=input_data||'  "featureid": "3",';
        input_data:=input_data||'  "category": [';

       for i in 1..410 loop
       input_data:=input_data||'    {';
       input_data:=input_data||'      "featureid": "3",';
       input_data:=input_data||'      "id": "'|| i ||'",';
       input_data:=input_data||'      "ischecked": false';
       input_data:=input_data||'    },';
       end loop;

       input_data:=input_data||'  ]';
       input_data:=input_data||'}';

       SELECT JSON_VALUE (input_data, '$.roleid' returning number) INTO lv_role_id FROM DUAL;
       dbms_output.put_line('JSON Size:'|| length(input_data));
       dbms_output.put_line('Role:'|| lv_role_id);

   end;
 /
JSON Size:31110
Role:2945


PL/SQL procedure successfully completed.

SQL>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...