设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2288|回复: 0
打印 上一主题 下一主题

[其它] 客户端调用Sqlserver存储过程时无记录集返回

[复制链接]
跳转到指定楼层
1#
发表于 2013-5-8 08:57:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
用VB做的客户端程序在调用服务器的存储过程时有的存储过程可以返回记录集,而有的无法返回记录集,这是为什么呢?
通过对存储过程的排查,发现问题在于结果集中返回可显示受 Transact-SQL 语句或存储过程影响的行计数的消息。也就是需要加上set nocount on语句。
SET NOCOUNT { ON | OFF }
备注
当 SET NOCOUNT 为 ON 时,不返回计数。当 SET NOCOUNT 为 OFF 时,返回计数。
即使当 SET NOCOUNT 为 ON 时,也更新 @@ROWCOUNT 函数。
当 SET NOCOUNT 为 ON 时,将不向客户端发送存储过程中每个语句的 DONE_IN_PROC 消息。如果存储过程中包含一些并不返回许多实际数据的语句,网络通信流量便会大量减少,因此,将 SET NOCOUNT 设置为 ON 可显著提高性能。
SET NOCOUNT 指定的设置是在执行或运行时生效,而不是在分析时生效。
示例
以下示例将禁止显示受影响的行数的消息。
USE AdventureWorks;
GO
SET NOCOUNT OFF;
GO
-- Display the count message.
Select TOP(5)LastName
FROM Person.Contact
Where LastName LIKE 'A%';
GO
-- SET NOCOUNT to ON to no longer display the count message.
SET NOCOUNT ON;
GO
Select TOP(5) LastName
FROM Person.Contact
Where LastName LIKE 'A%';
GO
-- Reset SET NOCOUNT to OFF
SET NOCOUNT OFF;
GO
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-4-30 01:33 , Processed in 0.082631 second(s), 24 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表