用Db::query()执行存储过程时,有多个返回结果集,会报错
The active result for the query contains no fields
需要在执行存储过程前,加入set nocount on;在退出存储过程的时候加上set nocount off
$res=Db::query("set nocount on;exec sp_fastconsumeaotu_qc '$cardno','$sn','$recordindex','$recorddoorno';set nocount off;");
$res=Db::query("set nocount on;
exec sp_fastconsumeaotu_qc '$cardno','$sn','$recordindex','$recorddoorno';
set nocount off;");
当set nocount 为NO的时候,不返回计数(受Transact-SQL语句影响行数)
当set nocount 为OFF时,返回计数(默认返回)
当 SET NOCOUNT 为 ON 时,将不给客户端发送存储过程中的每个语句的 DONE_IN_PROC 信息。当使用 Microsoft® SQL Server™ 提供的实用工具执行查询时,在 Transact-SQL 语句(如 SELECT、INSERT、UPDATE 和 DELETE)结束时将不会在查询结果中显示"nn 行受影响"。
如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。
SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。
注释当SET NOCOUNT 为ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。当SET NOCOUNT 为OFF 时,返回计数。 … 结论:我们应该在存储过程的头部加上SET NOCOUNT ON 这样的话,在退出存储过程的时候加上SET NOCOUNT OFF这样的话,以达到优化