软件定制 成功研发:ERP系统,OA系统,CRM系统,进销存,外贸进销存销售系统,项目管理系统 

 
 

首   页  |  成功案例  |  关于我们  |  软件产品  |  软件定制  |  编程知识  |  行业知识  |  WEB开发  |  联系我们

 
     
SETNOCOUNT的用法和注意事项  
 

  <p>当SETNOCOUNT为ON时,不返回计数(表示受Transact-SQL语句影响的行数)。当SETNOCOUNT为OFF时,返回计数。<br/>
即使当SETNOCOUNT为ON时,也更新@@ROWCOUNT函数。<br/>
当SETNOCOUNT为ON时,将不给客户端发送存储过程中的每个语句的DONE_IN_PROC信息。当使用Microsoft&reg;SQLServer&trade;提供的实用工具(QA)执行查询时,在Transact-SQL语句(如SELECT、INSERT、UPDATE和DELETE)结束时将不会在查询结果中显示&quot;nnrowsaffected&quot;。<br/>
如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。<br/>
SETNOCOUNT设置是在执行或运行时设置,而不是在分析时设置。<br/>
如果存储过程中有多个语句,则默认情况下,SQLServer在每个语句完成时给客户端应用程序发送一条消息,详细说明每个语句所影响的行数。大多数应用程序不需要这些消息。如果确信应用程序不需要他们,可以禁用这些消息,以提高慢速网络的性能。我们就可以通过SETNOCOUNT会话设置为应用程序禁用这些消息。(其实大部分应用程序都不需要这个值)<br/>
需要注意的是:<br/>
1.存储过程:<br/>
象table返回了记录集,而且连into语句也返回了记录集,不过该记录集得一种特别的记录集(没有字段,不能对该记录集进行任何操作),OLEDB和ODBC存在一个很大的差别,向odbc取记录集时,odbc过滤了上面所称的特殊记录集(那种只占位置但不能进行任何操作的记录集&mdash;&mdash;多由table或into产生),而向oledb取记录集时,oledb并没有将特殊记录集过滤。所以在使用存储过程返回记录集时,在不希望返回记录的地方,应该使用setnoon禁止存储过程返回记录集,否则可能会绕很多弯路。<br/>
2.触发器:<br/>
&nbsp;&nbsp;&nbsp;&nbsp;建议不要让触发器返回任何结果。这是因为对这些返回结果的特殊处理必须写入每个允许对触发器表进行修改的应用程序中。为了阻止从触发器返回任何结果,不要在触发器内定义包含SELECT语句或变量赋值。如果必须在触发器中进行变量赋值,则应该在触发器的开头使用SETNOCOUNTON语句以避免返回任何结果集。<br/>
&nbsp;&nbsp;&nbsp;&nbsp;今天我就遇到了触发器返回结果集,造成对触发器表删除出错,如果是删除一条记录可以,多条则不行,提示:Keycolumninfmationsiinsufficientincrect.Toomanyrowswereaffectedby</p>



 

知识库

 








首 页 | 成功案例 | 关于我们 | 软件产品 | 软件定制 | 代理合作 | 售后服务 | 在线演示 | 联系我们

业务QQ:在线客服  技术QQ:在线技术支持 MSN:
Copyright (C) 深圳市凯路网络技术有限公司
粤ICP[07018848]号
软件知识 行业最新信息 编程技巧等尽在这里