向高手救助:关于java中jdbc读取数据库的问题!!!!!!!!!!!!!!!!!!!

代码如下:publicString[]getDiaryList(){String[]name={""};StringDiary="jdbc:odbc:Diary";int... 代码如下:
public String[] getDiaryList()
{
String [] name = {""};
String Diary = "jdbc:odbc:Diary";
int i=0;
try
{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection conn = DriverManager.getConnection(Diary,"","");
Statement st = conn.createStatement();
ResultSet rec = st.executeQuery("SELECT * FROM Diary ORDER BY ID");
while (rec.next())
{
System.out.println(rec.getString("diaryName"));//此处可以输出数据库内的东西。。。
name[i] = rec.getString("diaryName");
i++;
}
}
catch (Exception e)
{
System.out.println("Wrong: "+e.toString());
}
return(name);
}
本想用name[]获取数据库中的内容
可是发现一运行就报错:java.sql.SQLException:No Data Found!
但是在对name[]赋值之前的直接打印输出是没问题的。所以应该不是数据库的连接问题,请高手帮忙看看,谢了先!!!!!!!
to lirong1978:
改了之后还是不行,仍然报No Data Found的错
展开
 我来答
cyq1857
2007-04-13 · TA获得超过818个赞
知道小有建树答主
回答量:583
采纳率:0%
帮助的人:303万
展开全部
首先lirong1978说的你要改,否则这个数组只有一个元素了

然后同一行数据的某一字段做了两次操作就不可以了,这应当是驱动程序的问题,这和这个驱动的实现有关系的,这样你可以把结果先放到一个临时变量里面就可以了

String temp=rec.getString("diaryName");
System.out.println(temp);//此处可以输出数据库内的东西。。。
name[i] = temp;
i++;
百度网友c547160
2007-04-10 · TA获得超过1377个赞
知道小有建树答主
回答量:2447
采纳率:0%
帮助的人:2095万
展开全部
String [] name = {""}; 这是什么东西啊,就一个啊

String []name =new String[100],自己设置一下吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
paccer
2007-04-10 · TA获得超过920个赞
知道小有建树答主
回答量:1617
采纳率:100%
帮助的人:1360万
展开全部
读取resultset的内容,只能一行行来

所以你的代码非常正确,没有别的法子
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式