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

asp页面显示不正常

jishang1983 发布于 2012-10-20 17:31, 646 次点击
<select multiple size="10" name="list4" id="list4" style="width:200px">
                    <%
                        for i=0 to ubound(arr_bmid)
                        set rs=server.CreateObject("adodb.recordset")
                        rs.open "select * from BWOA_bumen where id="&cint(arr_bmid(i)),conn,1,1
                        if not rs.eof then
                    %>
                        <option value="<%=rs("id")%>"><%=rs("BM_mc")%></option>
                    <%
                        end if
                        rs.close
                        set rs=nothing
                        next
                    %>
</select>
这段代码请高手帮忙看一下,select在表格第一行的某一列,本身显示没有问题,但是表格的其它行都不显示了,而且没有任何报错,不知道是什么原因

[ 本帖最后由 jishang1983 于 2012-10-20 17:38 编辑 ]
9 回复
#2
青春无限2012-10-20 18:06
  看看
#3
hu9jj2012-10-20 21:19
换成这样试试:
<%
    set rs=server.CreateObject("adodb.recordset")
    rs.open "select * from BWOA_bumen where id="&cint(arr_bmid(i)),conn,1,1
    for i=0 to ubound(arr_bmid)
    if not rs.eof then
%>
#4
jishang19832012-10-20 23:06
回复 3楼 hu9jj
吼,这样可以了,非常感谢,这是为什么呢
#5
jishang19832012-10-20 23:07
回复 3楼 hu9jj
看错了,这样不行啊
#6
jishang19832012-10-20 23:09
回复 3楼 hu9jj
sql语句里用的i是在for循环里定义的,不能把语句放外面
#7
hu9jj2012-10-21 08:57
通常建立数据库的连接只要一次就行,很少会放在循环中反复建立。数据集提取出来后通过循环逐条显示出来,也很少会在循环中反复提取数据集。由于不了解你的思路,所以修改的建议也不一定正确,仅供参考。
#8
jishang19832012-10-21 11:15
回复 7楼 hu9jj
谢谢
#9
ysf01812012-10-21 13:35
<select multiple size="10" name="list4" id="list4" style="width:200px">
                    <%
                        set rs=server.CreateObject("adodb.recordset")
                        for i=0 to ubound(arr_bmid)
                        rs.open "select * from BWOA_bumen where id="&clng(arr_bmid(i)),conn,1,1
                        if not rs.eof then
                    %>
                        <option value="<%=rs("id")%>"><%=rs("BM_mc")%></option>
                    <%
                        end if
                        rs.close
                        next
                        set rs=nothing

                    %>
</select>
这样估计就可以了。
#10
jishang19832012-10-21 17:28
回复 9楼 ysf0181
我改了sql语句了,id=改成id in 了,把数组换成字符串,遍历rs就没问题了,多谢
1