JAVA&JSP高手请进(有关无效索引的问题)

//数据库里面的绝对没有一点问题,··!!!<%@pagelanguage="java"contentType="text/html;charset=GB18030"pa... //数据库里面的绝对没有一点问题,··!!!
<%@ page language="java" contentType="text/html; charset=GB18030"
pageEncoding="GB18030"%>
<%@ page import = "java.sql.*" %>
<%! String str = ""; %>
<%!
private void tree(Connection conn, int id){
System.out.println(" a run tree()");
Statement stmt = null;
ResultSet rs = null;
try{
stmt = conn.createStatement();
rs = stmt.executeQuery("select * from article where pid ="+id);
while(rs.next()){
str += "<tr><td>"+ rs.getInt("id") +"</td><td>"+ rs.getString("title") + "</td><tr>";
if(rs.getInt("isleaf")!=0){
tree(conn,rs.getInt("id"));
}
}
} catch(SQLException e){
e.printStackTrace();
}finally{
try{
if(rs != null){
rs.close();
rs = null;
}
if(stmt != null){
stmt.close();
stmt = null;
}
if(conn != null){
conn.close();
conn = null;
}
} catch(SQLException e){
e.printStackTrace();
}
}
}
%>

<%
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
} catch(ClassNotFoundException e){ e.printStackTrace(); }
try{
conn = DriverManager.getConnection("Jdbc:Odbc:sun","sa","");
stmt = conn.createStatement();
String sql = "";
sql = "select * from article where pid=0";
rs = stmt.executeQuery(sql);
System.out.println(sql);
while(rs.next()){
str += "<tr><td>"+rs.getInt("id")+"</td><td>"+rs.getString("title")+"</td></tr>";

if(rs.getInt("isleaf")!=0){

tree(conn,rs.getInt("id"));
}
rs.close();
stmt.close();
conn.close();
}
} catch(SQLException e){
e.printStackTrace();
}

%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB18030">
<title>Insert title here</title>
</head>
<body>

<table border = "1">
<%= str %>
</table>

</body>
</html>

错误报告如下:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]无效的描述符索引
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6957)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7114)
展开
 我来答
tld12
2008-04-18 · TA获得超过170个赞
知道小有建树答主
回答量:233
采纳率:0%
帮助的人:141万
展开全部
在jsp对sqlserver数据库进行数据读取的时候,
必须按照表中列名的顺序读取,否则会出现错误

取数据的时候要按照数据库字段的顺序来取
比如数据库 varchar id
varchar name
varchar address

取的时候一定要按下面顺序来取:
rs.getString("id")
rs.getString("name")
rs.getString("address")
再赋值
String s1=rs.getString("id");
String s2=rs.getString("name");
String s3=rs.getString("address");
之后可以随意顺序使用s1,s2,s3了!
阳光明媚啊呀3549
2008-04-19 · TA获得超过112个赞
知道答主
回答量:292
采纳率:0%
帮助的人:0
展开全部
rs = stmt.executeQuery("select * from article where pid ="+id);
这句话有问题吧 没暴黄?还是没看到啊? id 这个变量上面都没有定义啊
你把整个的sql语句打出来看一下吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
乌微月2S
2008-04-18 · TA获得超过5037个赞
知道大有可为答主
回答量:5361
采纳率:42%
帮助的人:2883万
展开全部
rs = stmt.executeQuery("select * from article where pid ="+id); 写错了,少单引号!
rs = stmt.executeQuery("select * from article where pid ='"+id+"'");
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友4c3545f1a
2008-04-18 · 超过23用户采纳过TA的回答
知道答主
回答量:195
采纳率:0%
帮助的人:91.8万
展开全部
好像是你链接数据库语句有问题
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
燕七七YQQ
2008-04-25 · 超过21用户采纳过TA的回答
知道答主
回答量:171
采纳率:0%
帮助的人:0
展开全部
代码太乱了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式