qt调用sql server存储过程并获取output参数

Posted 骑单车的攻城狮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了qt调用sql server存储过程并获取output参数相关的知识,希望对你有一定的参考价值。

最近新做的一个项目需要使用qt5连接另一台机器上的sql server,虽然网上已有类似文章,但还是有些其中很少提及的问题,故在这里汇总下:

  qt连接sql server可以参考这篇文章:

《Qt 使用ODBC driver 连接SQL Server》

如果是连接另一台机器的sql server就不用执行第一步“开启ODBC驱动”了,另外指定数据库用户名和密码可以使用Uid和Pwd,即原文dsn参数可以这样写:

QString dsn = QString("Driver={SQL Server};Server=%1;Database=%2;Uid=%3;Pwd=%4").arg(serverName).arg(dbName).arg(userName).arg(password);

 而且“Trusted_Connection=yes”也要删除,否则会报错。

 

  关于如何调用存储过程可以参考如下文章:

《Qt调用Server SQL中的存储过程》

其中QSqlQuery::prepare()的参数怎么写,其实只要在SQL Server Management Studio中先调用下存储过程就会自动生成调用代码,EXEC那部分再精简下即可直接使用了。

推荐使用Oracle格式占位符即冒号方式如:argname,相比ODBC格式的?占位符方便很多。另外如果是多个output参数,可以用这样写:

query.prepare("exec PINSERTPC :arg1 output, :arg2 output");

 

最后还有一个需要注意的地方,sql server需要在所有结果集都被遍历后才能通过query.boundValue获取output参数的值,未遍历前获取的其实仍是query.bindValue时的默认值,具体可以参见bool QSqlQuery::nextResult()的介绍:

Note that some databases, i.e. Microsoft SQL Server, requires non-scrollable cursors when working with multiple result sets. Some databases may execute all statements at once while others may delay the execution until the result set is actually accessed, and some databases may have restrictions on which statements are allowed to be used in a SQL batch.

 

以上是关于qt调用sql server存储过程并获取output参数的主要内容,如果未能解决你的问题,请参考以下文章

Yii2.0调用sql server存储过程并获取返回值

sql server远程调用失败怎么解决

sql server存储过程如何输出结果集

SQL Server通过条件搜索获取相关的存储过程等对象

JPA 2.1在sql server中调用存储过程

从 SQL Server 存储过程中获取结果