Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

não pode receber o parâmetro do procedimento oracle executado pelo mybatis


encontrei solução. O mapa deve ser usuário em vez de dois parâmetros no método canCustomerSubscribe.
 void canCustomerSubscribe(Map<String,Object> params);

conteúdo xml do mybatis:
<select id="canCustomerSubscribe" parameterType="java.util.HashMap" statementType="CALLABLE">
    CALL wallet.pkg_wallet_validation.can_customer_subscribe(
    #{msisdn, jdbcType=VARCHAR, javaType=java.lang.String, mode=IN},
    #{responseCode,jdbcType=NUMERIC, javaType=java.lang.Integer, mode=OUT})
</select>

(Eu preciso adicionar as vírgulas entre os atributos de argumentos)

chamando-o do método de serviço de assinatura:
public void subscribe(String msisdn) throws InvalidArgumentException {
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("msisdn", msisdn);
    params.put("responseCode", null);
    subscriberMapper.canCustomerSubscribe(params);
    System.out.println(params.get("responseCode"));
}