爱问知识人 爱问教育 医院库

很奇怪的问题,希望高手指教

首页

很奇怪的问题,希望高手指教

一段Servlet程序如下: 
String sql="insert into BK_addword (BK_addword_title,BK_addword_word) values ('12','22')SELECT @@IDENTITY AS 'id'"; 
rs = stmt.executeQuery(sql); 
 xt(); 
word=  tInt("id"); 
在windowssever2003+tomcat+SQL2000下一切正常可以输出插入那条信息的id值,但是换到Vista+tomcat+SQL2008下就出现【该语句没有返回结果集】的错误,更奇怪的是我将程序修改为下面情况: 
String sql="insert into BK_addword (BK_addword_title,BK_addword_word) values ('12','22')"; 
stmt.executeUpdate(sql); 
sql="SELECT @@IDENTITY AS 'id'"; 
rs = stmt.executeQuery(sql); 
 xt(); 
word=  tInt("id"); 
此时在Vista+tomcat+SQL2008下用Eclipse写成java程序调试时可以正确显示id,写成jsp页面时也可以正确显示,偏偏写成Servlet时返回的id值却成了0。我也试着开始给这个word变量赋值为-1,可是运行后还是变成0,这说明Servlet程序没有问题而且进行到了word=  tInt("id");这步,但是为什么却是0,而用其他方式调试却正常了,求助高手指教,分数不多,谢谢!

提交回答
好评回答
  • 2009-04-07 12:03:20
      数据库配置问题
    没有把nocount关闭
    推荐使用存储过程
    set nocount off
    String sql = "insert into BK_addword (BK_addword_title,BK_addword_word) values ('12','22')select @@identity as id";
    rs = stmt。
      executeQuery(sql); 如果还不行,把以上语句在一个存储过程里 存储过程: create proc test @aa int output as insert into BK_addword (BK_addword_title,BK_addword_word) values ('12','22') select @@identity as id go 调用语句 sql = "declare @aa int;exec test @aa output;select @aa as bb" rs = stmt。
      executeQuery(sql); xt(); word = tInt("bb"); 关于nocount: 当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)。当 SET NOCOUNT 为 OFF 时,返回计数。
         即使当 SET NOCOUNT 为 ON 时,也更新 @@ROWCOUNT 函数。   当 SET NOCOUNT 为 ON 时,将不给客户端发送存储过程中的每个语句的 DONE_IN_PROC 信息。当使用 Microsoft® SQL Server™ 提供的实用工具(QA)执行查询时,在 Transact-SQL 语句(如 SELECT、INSERT、UPDATE 和 DELETE)结束时将不会在查询结果中显示"nn rows affected"。
         如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。   SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。   如果存储过程中有多个语句,则默认情况下,SQL Server在每个语句完成时给客户端应用程序发送一条消息,详细说明每个语句所影响的行数。
      大多数应用程序不需要这些消息。如果确信应用程序不需要他们,可以禁用这些消息,以提高慢速网络的性能。我们就可以通过SET NOCOUNT会话设置为应用程序禁用这些消息。(其实大部分应用程序都不需要这个值)   需要注意的是:   1.存储过程:   象create table返回了记录集,而且连insert into语句也返回了记录集,不过该记录集得一种特别的记录集(没有字段,不能对该记录集进行任何操作), OLEDB和ODBC存在一个很大的差别,向odbc取记录集时,odbc过滤了上面所称的特殊记录集(那种只占位置但不能进行任何操作的记录集——多由create table或insert into产生),而向oledb取记录集时,oledb并没有将特殊记录集过滤。
      所以在使用存储过程返回记录集时,在不希望返回记录的地方,应该使用set nocount on禁止存储过程返回记录集,否则可能会绕很多弯路。   2.触发器:   建议不要让触发器返回任何结果。这是因为对这些返回结果的特殊处理必须写入每个允许对触发器表进行修改的应用程序中。
      为了阻止从触发器返回任何结果,不要在触发器内定义包含SELECT语句或变量赋值。如果必须在触发器中进行变量赋值,则应该在触发器的开头使用SET NOCOUNT ON语句以避免返回任何结果集。   今天我就遇到了触发器返回结果集,造成对触发器表删除出错,如果是删除一条记录可以,多条则不行,提示:Key column information si insufficient or incorrect。
      Too many rows were affected by update。

    k***

    2009-04-07 12:03:20

类似问题

换一换

相关推荐

正在加载...
最新问答 推荐信息 热门专题 热点推荐
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200
  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 181-200

热点检索

  • 1-20
  • 21-40
  • 41-60
  • 61-80
  • 81-100
  • 101-120
  • 121-140
  • 141-160
  • 161-180
  • 175-194
返回
顶部
帮助 意见
反馈

确定举报此问题

举报原因(必选):