表格中怎样通过传递参数呢????

szabo 2003-08-18 04:12:28
为什么我在JSP文件中用:
<td><a href="modifyData1.jsp? ID=<%=rs.getString("ISBN")%>">修改</a></td>

就出现如下错误呢?
<a href="deleteData1.jsp? ID=数据库连接错误:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]无效的描述符索引


怎样来传递参数呀????
...全文
309 20 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
Geranium 2003-08-22
  • 打赏
  • 举报
回复
mark
szabo 2003-08-22
  • 打赏
  • 举报
回复
多谢:junsunchen(渴望高飞的人)
kevincom(木瓜)
cainiao_2000(cainiao)
三位兄兄啊~~~~~~~~~~~~~~~~~~~~~~~~~.
cainiao_2000 2003-08-22
  • 打赏
  • 举报
回复
while(rs.next()){
String temp=rs.getString("ISBN");
%>
<tr>
<td><%=temp%></td>
<td><%=rs.getString("TITLE")%></TD>
<td><%=rs.getString("AUTHOR")%></td>
<td><%=rs.getString("PRESSNAME")%></td>
<td><a href="modifyData1.jsp?ID=<%=temp%>">修改</a></td>
<td><a href="deleteData1.jsp"ID=<%=temp%>&ISBN=<%=temp%>">删除</a></td>

</tr>

原因:Statement st=conn.createStatement();中的createStatement()函数没有参数的情况下是创建只读(read-only)的向前(forward)的Statement,当next后对每个数据只能获取一次,要多次的话,要保存到一个临时变量里

kevincom(木瓜) :
你漏了等号:=了
kevincom 2003-08-22
  • 打赏
  • 举报
回复
<%@ page contentType="text/html;charset=GBK"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.sql.*"%>
<%@ page import="javax.naming.*"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<title>
Book List.
</title>
</head>
<body>
<%
Connection conn=null;
String it=null;
try{
request.setCharacterEncoding("GB2312");
InitialContext ic=new InitialContext();
DataSource ds=(DataSource)ic.lookup("jdbc/JDBCConnectionCoreDS");
conn=ds.getConnection();
Statement st=conn.createStatement();
String ISBN=request.getParameter("ISBN");
if(ISBN!=null&&!ISBN.equals("")){
out.println("<b>查找书号'"+ISBN+"'</b>");
}
else{
out.println("<b>已登录的图书如下:</b>");
}
%>
<table border=1>
<tr>
<td>书号</td>
<td>书名</td>
<td>作者</td>
<td>出版社</td>
<td>修改</td>
<td>删除</td>
</tr>
<%
String sql="select * from books";
if(ISBN!=null && !ISBN.equals("")){
sql+=" where ISBN like '%"+ISBN+"%'";
}
ResultSet rs=st.executeQuery(sql);
while(rs.next()){
String temp=rs.getString("ISBN");
%>
<tr>
<td><%temp%></td>
<td><%=rs.getString("TITLE")%></TD>
<td><%=rs.getString("AUTHOR")%></td>
<td><%=rs.getString("PRESSNAME")%></td>
<td><a href="modifyData1.jsp?ID=<%temp%>">修改</a></td>
<td><a href="deleteData1.jsp"ID=<%temp%>&ISBN=<%temp%>">删除</a></td>

</tr>
<%
}
rs.close();
st.close();
%>
</table>
<p><a href="insertData1.jsp">添加新图书</a>   
<form action=bookList.jsp method=post>
<input name=ISBN>
<input type=submit value=查找>
</form>
<%
}
catch(SQLException e){
out.println("数据库连接错误:"+e);
}
finally{ conn.close();}
%>

</body>
</html>
kevincom 2003-08-22
  • 打赏
  • 举报
回复
你多次用了rs.getString("ISBN")了
在while循环开始用一个变量如:
String temp=rs.getString("ISBN"),
下面就用这个变量
不要重复用rs.getString("ISBN")试试
szabo 2003-08-22
  • 打赏
  • 举报
回复
多谢各位 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
szabo 2003-08-21
  • 打赏
  • 举报
回复
原程序如下,为什么会出现上述所说的错误呀???

<%@ page contentType="text/html;charset=GBK"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.sql.*"%>
<%@ page import="javax.naming.*"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<title>
Book List.
</title>
</head>
<body>
<%
Connection conn=null;
String it=null;
try{
request.setCharacterEncoding("GB2312");
InitialContext ic=new InitialContext();
DataSource ds=(DataSource)ic.lookup("jdbc/JDBCConnectionCoreDS");
conn=ds.getConnection();
Statement st=conn.createStatement();
String ISBN=request.getParameter("ISBN");
if(ISBN!=null&&!ISBN.equals("")){
out.println("<b>查找书号'"+ISBN+"'</b>");
}
else{
out.println("<b>已登录的图书如下:</b>");
}
%>
<table border=1>
<tr>
<td>书号</td>
<td>书名</td>
<td>作者</td>
<td>出版社</td>
<td>修改</td>
<td>删除</td>
</tr>
<%
String sql="select * from books";
if(ISBN!=null && !ISBN.equals("")){
sql+=" where ISBN like '%"+ISBN+"%'";
}
ResultSet rs=st.executeQuery(sql);
while(rs.next()){
%>
<tr>
<td><%=rs.getString("ISBN")%></td>
<td><%=rs.getString("TITLE")%></TD>
<td><%=rs.getString("AUTHOR")%></td>
<td><%=rs.getString("PRESSNAME")%></td>
<td><a href="modifyData1.jsp?ID=<%=rs.getString("ISBN")%>">修改</a></td>
<td><a href="deleteData1.jsp"ID=<%=rs.getString("ISBN")%>&ISBN=<%=rs.getString("ISBN")%>">删除</a></td>

</tr>
<%
}
rs.close();
st.close();
%>
</table>
<p><a href="insertData1.jsp">添加新图书</a>   
<form action=bookList.jsp method=post>
<input name=ISBN>
<input type=submit value=查找>
</form>
<%
}
catch(SQLException e){
out.println("数据库连接错误:"+e);
}
finally{ conn.close();}
%>

</body>
</html>


我调了几天了,也没有弄出来啊!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
郁闷啊。。。。。。。。。。。。。。。。。。。。。。
kevincom 2003-08-21
  • 打赏
  • 举报
回复
是不是你没在得到rs之后没有
rs.next()啊?
在刚返回记录集时光标位于第一条记录之前
这时应先rs.next()
znjq1001 2003-08-21
  • 打赏
  • 举报
回复
rs中没有ISBN字段 !!!
cricketlj 2003-08-21
  • 打赏
  • 举报
回复
SQLException,你的sql能执行吗?
szabo 2003-08-21
  • 打赏
  • 举报
回复
有没有别的方法来传递参数啊????
junsunchen 2003-08-19
  • 打赏
  • 举报
回复
可能因为你上面已经调用过rs.getString("ISBN")%>">一次了,你再调用它就会出错,我也碰到过你种情况!
szabo 2003-08-19
  • 打赏
  • 举报
回复
老大们,想个法子啊!!!
szabo 2003-08-19
  • 打赏
  • 举报
回复
我还是没有解决这个问题啊?????????????????????
szabo 2003-08-18
  • 打赏
  • 举报
回复
TO:pumag(大米):

什么光标位置????
gree001 2003-08-18
  • 打赏
  • 举报
回复
?

楼上说的是虾米?
pumag 2003-08-18
  • 打赏
  • 举报
回复
rs.getString("ISBN")出错了,光标位置不对
szabo 2003-08-18
  • 打赏
  • 举报
回复
我把空格去掉还是不行啊,还是出同样的错误呀!!!!!!!!!
还有没有别的办法啊????
jsidiot 2003-08-18
  • 打赏
  • 举报
回复
<td><a href="modifyData1.jsp?ID=<%=rs.getString("ISBN")%>">修改</a></td>
多一个空格
szabo 2003-08-18
  • 打赏
  • 举报
回复
我急啊,我在线线上等啊,老大们~~~~~~~~~~~~~~~
资源下载链接为: https://pan.quark.cn/s/1bfadf00ae14 松下电工数字压力传感器用户手册详细介绍了DP-100系列数字压力传感器,涵盖其技术参数、操作方法及适用场景等,适用于各类需要精准压力测量的工业环境。 双屏显示:主屏与输出动作同步,可同时显示当前值和基准值,便于实时监控与调整。显示屏为12段字母数字显示,数字清晰易读。 三色指示:屏幕颜色随传感器状态变化(红、绿、橙),便于快速判断工作状态。 紧凑结构:尺寸仅□30mm,适合空间狭窄的安装环境。 多种操作模式:提供RUN模式(日常操作)、菜单设定模式(深入设置如输出模式切换)及PRO模式(高级功能如应差调整、复制设定)。 安全认证:DP-101(A)/102(A)型号通过特定认证,确保产品安全可靠。 复制功能:可通过数据通信将主传感器设定内容复制到其他传感器,减少人工设定错误,节省时间。 高性能传感:具备高精度,分辨率1/2,000,反应时间2.5ms(最长5,000ms可调),温度特性±0.5%F.S.,重复精度±0.1%F.S. 电子元件吸附检测:监测吸盘是否成功吸附电子元件。 总压力监测:测量管道或容器内的压力水平。 空气泄漏检测:通过压力变化检测泄漏情况。 DP-101□:适用于低压环境(-100kPa至100kPa)。 DP-102□:适用于高压环境(0kPa至1MPa)。 订购时需根据实际需求选择合适型号,考虑传感器的适用范围和工作条件。手册提供详细订购流程及注意事项,包括相关认证信息(如韩国S标志)。 复制功能:通过数据通信将主传感器设定复制到其他传感器,支持多种设定模式,避免设定错误,节省时间。 操作模式:RUN模式用于日常监控,菜单设定模式用于深入设置,PRO模式提供高级功能。 使用前需仔细阅读手册,了解各功能使用方法。遵循安全指南,正确安装和使用传感器,避免损坏。对于

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧