Ошибка ресурса ресурса в службе данных WSO2 с процедурой без параметра - PullRequest
0 голосов
/ 13 декабря 2018

Привет! Я создаю службу данных WSO2 и вызываю хранимую процедуру с параметром out.

{call ? :=IRIS_REST_PKG.INSERT_OR_UPDATE_STUDENT(?,?,?) }

Так что я могу заставить все это работать в редакторе try it, но когда я настраиваю ресурс rest, я вижу список параметров запроса, который включает в себя мой параметр out, который был ранее определен в запросе.Когда я звоню в службу отдыха только с параметрами, я получаю:

Value type miss match, Expected value type - 'null', but found - 'STRING'.

Я использую версию 6.4.0 Enterprise Intergrator.Это мой файл базы данных:

<data name="IRIS" transports="http https local">
   <config enableOData="false" id="ORACLE">
      <property name="driverClassName">oracle.jdbc.driver.OracleDriver</property>
      <property name="url">jdbc:oracle:thin:@ldap:...</property>
      <property name="username">xxxxxxxxxxxx</property>
      <property name="password">xxxxxxxxxxxx</property>
      <property name="dataSourceProps"/>
      <property name="dynamicUserAuthMapping">
         <configuration/>
      </property>
   </config>
   <query id="get_student" useConfig="ORACLE">
      <sql>{call ?:=TEST_PKG.get_student(?)}</sql>
      <result element="upi" rowName="">
         <element column="upi" name="upi" xsdType="string"/>
         <element column="research_summary" name="research_summary" xsdType="string"/>
      </result>
      <param name="result" sqlType="ORACLE_REF_CURSOR" type="OUT"/>
      <param name="upi" sqlType="STRING"/>
   </query>
   <query id="q1" useConfig="ORACLE">
      <sql>{call ?:=TEST_PKG.myfunction(?,?)}</sql>
      <result element="myCount" rowName="">
         <element column="myCount" name="myCount" xsdType="integer"/>
      </result>
      <param name="myCount" sqlType="INTEGER" type="OUT"/>
      <param name="ename" sqlType="STRING"/>
      <param name="eid" sqlType="INTEGER"/>
   </query>
   <query id="insert_or_update_student" useConfig="ORACLE">
      <sql>{call ? :=IRIS_REST_PKG.INSERT_OR_UPDATE_STUDENT(?,?,?) }</sql>
      <result outputType="json">{"result":{"status":"$status"}}</result>  
      <param defaultValue="-1" name="status" sqlType="INTEGER" type="OUT"/>
      <param name="upi" sqlType="STRING"/>
      <param name="summary" sqlType="STRING"/>
      <param name="optIn" sqlType="INTEGER"/>
   </query>
   <query id="get_jstudent" useConfig="ORACLE">
      <sql>SELECT UPI, RESEARCH_SUMMARY FROM xxx r WHERE r.UPI = :upi</sql>
      <result outputType="json">{"result":{"upi":"$upi","research_summary":"$research_summary"}}</result>
      <param name="upi" sqlType="STRING"/>
   </query>
   <operation name="get_student">
      <call-query href="get_student">
         <with-param name="upi" query-param="upi"/>
      </call-query>
   </operation>
   <operation name="op1">
      <call-query href="q1">
         <with-param name="ename" query-param="ename"/>
         <with-param name="eid" query-param="eid"/>
      </call-query>
   </operation>
   <operation name="insert_or_update_student">
      <call-query href="insert_or_update_student">
         <with-param name="upi" query-param="upi"/>
         <with-param name="summary" query-param="summary"/>
         <with-param name="optIn" query-param="optIn"/>
      </call-query>
   </operation>
   <operation name="get_jstudent">
      <call-query href="get_jstudent">
         <with-param name="upi" query-param="upi"/>
      </call-query>
   </operation>
   <resource method="GET" path="r1">
      <call-query href="get_student">
         <with-param name="result" query-param="result"/>
         <with-param name="upi" query-param="upi"/>
      </call-query>
   </resource>
   <resource method="POST" path="insertOrUpdateStudent">
      <call-query href="insert_or_update_student">
         <with-param name="status" query-param="status"/>
         <with-param name="upi" query-param="upi"/>
         <with-param name="summary" query-param="summary"/>
         <with-param name="optIn" query-param="optIn"/>
      </call-query>
   </resource>
   <resource method="GET" path="get_jstudent/{upi}">
      <call-query href="get_jstudent">
         <with-param name="upi" query-param="upi"/>
      </call-query>
   </resource>
</data>

Я говорю о: разделе ресурса insertOrUpdateStudent.

<with-param name="status" query-param="status"/> 

Я также удалил эту строку, но все еще не работает.Я также попытался передать null / 0 / "" и до сих пор не работает.

Любая помощь будет принята с благодарностью.

Спасибо.

1 Ответ

0 голосов
/ 19 декабря 2018

Ответ таков: если ресурс и операция имеют одно и то же имя, все пойдет не так.Также, даже с учетом вышеприведенного правильного, мастер отображает выходной параметр в качестве параметра запроса, поэтому нужно отредактировать xml и удалить выходной параметр из параметров ресурса.

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