qt调用oracle存储过程

时间:2012-12-17 11:27:37

标签: oracle qt stored-procedures output-parameter qsqlquery

我使用QsqlQuery来调用使用输入参数和两个输出参数的oracle存储过程 该过程执行得很完美,但输出参数不包含数据

QSqlQuery movementQuery ;
movementQuery.prepare("call Qt.add_movement(:pDocumentType , :pDocumentId ,       
to_date(sysdate,'dd-mm-yyyy') ,:pDocumentNumber"
",to_date(sysdate,'dd-mm-yyyy') , :pCustId ,:pMovementId ,:pReturn )");
movementQuery.bindValue(":pDocumentType",documentType);
movementQuery.bindValue(":pDocumentId",documentId);
movementQuery.bindValue(":pDocumentNumber",0);
movementQuery.bindValue(":pCustId",ui->custId->text());
movementQuery.bindValue(":pMovementId", 0, QSql::Out);
movementQuery.bindValue(":pReturn", "FALSE", QSql::Out);
movementQuery.exec();
 //// The query executed the query is active and no errors are valid
//// message is method to display the value
message(query.boundValue(":pReturn").toString());
message(query.boundValue(5).toString());
message(query.boundValue(":pMovementId").toString());
message(query.boundValue(4).toString());

任何想法 感谢您的关注

1 个答案:

答案 0 :(得分:1)

您正在执行movementQuery

movementQuery.exec();

但是您要返回query的绑定值。

message(query.boundValue(":pReturn").toString());