注册 登录
编程论坛 ASP技术论坛

一个百思不得其解的错误。第279行 rs.close 的时候就会出错,我明明创建了对象,硬说我没有。。。

isbn0000 发布于 2011-03-20 23:26, 664 次点击
程序代码:


 <table border="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" id="AutoNumber3">
    <tr>
      <td width="100%" height="25"><b><font color="#000080" size="3">二、多项选择题(每题<%=multiper%>分,共<%=multicount%>题。每题至少有2项正确的答案,少选每答对一题得<%=multiper/4%>分,多选不得分)</font></b></td>
    </tr>
  </table>
<%
for i=singlecount to multicount+singlecount-1
sql
="select * from exam_database where ID="&subject_id(i)
set rs=server.createobject("adodb.recordset")
rs.open sql,conn,
3,2
if not rs.eof then
%>
  <table border="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" id="AutoNumber2">
    <tr>
      <td width="100%" bgcolor="#EFEFEF" height="20">&nbsp;&nbsp;<b><%=i+1%><%=rs("question")%></b></td>
    </tr>
    <%
  
if trim(rs("text1"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="A">A、<%=rs("text1")%></td>
    </tr>
    <%
  
end if
  
%>
  <%
  
if trim(rs("text2"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="B">B、<%=rs("text2")%></td>
    </tr>
    <%
  
end if
  
%> <%
  
if trim(rs("text3"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="C">C、<%=rs("text3")%></td>
    </tr>
    <%
  
end if
  
%> <%
  
if trim(rs("text4"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="D">D、<%=rs("text4")%></td>
    </tr>
    <%
  
end if
  
%> <%
  
if trim(rs("text5"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="E">E、<%=rs("text5")%></td>
    </tr>
    <%
  
end if
  
%> <%
  
if trim(rs("text6"))<>"" then
  
%>
    <tr>
      <td width="100%">&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="NO<%=rs("id")%>" value="F">F、<%=rs("text6")%></td>
    </tr>
    <%
  
end if
  
%>
  </table>
  <%
end if
next
rs.close
set rs=nothing
%>
6 回复
#2
isbn00002011-03-20 23:27
现在不是279行了,是代码的倒数第三行,rs.close 语句。
#3
hams2011-03-21 08:14
sql="select * from exam_database where ID="&subject_id(i)
set rs=server.createobject("adodb.recordset")

把这段放到循环外边
#4
isbn00002011-03-21 11:58
回复 3楼 hams
为什么我前面这样用可以,而同一文件里第二次这样语序就不可以额?
#5
hams2011-03-21 14:47
为什么前面能用我不知道,唯一的解释是只进行了一次循环,执行第二次就出错。
#6
isbn00002011-03-21 18:55
回复 4楼 isbn0000
是不是可以用exit关键字来终止每次循环。
#7
hams2011-03-22 08:09
这和循环没关系,在对象关闭前不要再打开
1