在asp.net运网页时,出现用户代码未处理indexoutofrangeexception,还有在位置零出没任何行。是什么原因?

publicstaticDataRowdr(stringquery){//返回一行记录OleDbConnectioncon=Class1.createconn();//u... public static DataRow dr(string query)
{
//返回一行记录
OleDbConnection con = Class1.createconn();
//using(con)
// {
//con.Class1();
OleDbDataAdapter sda = new OleDbDataAdapter(query, con);
DataSet ds = new DataSet();
sda.Fill(ds, "anounce");
return ds.Tables["anounce"].Rows[0]; // 在这提示出的错
//}
}
谁能解决啊!本人很急用。
展开
 我来答
Reyzhang
2011-06-04 · TA获得超过1111个赞
知道小有建树答主
回答量:805
采纳率:85%
帮助的人:670万
展开全部
这是因为没有取到数据的问题。你可以对ds做一下为null的判断
public static DataRow dr(string query) {
DataRow dr=null;
.....
....
DataSet ds = new DataSet();
sda.Fill(ds, "anounce");
if (ds.Tables["anounce"]!=null && ds.Tables["annouce"].Rows.Count>0)
{
dr=ds.Tables["anounce"].Rows[0];
}
return dr;
}
百度网友b68d4ea4f
2011-06-06 · TA获得超过126个赞
知道小有建树答主
回答量:182
采纳率:100%
帮助的人:139万
展开全部
return之前需要判断下ds.Tables["anounce"].Rows[0]; 是否存在。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
很大燕子
2011-06-03
知道答主
回答量:12
采纳率:0%
帮助的人:3.2万
展开全部
OleDbDataAdapter sda = new OleDbDataAdapter(query, con) 从数据库中没读到数据,可能是query 中的sql语句有问题.
追问
还提示为:1.确保列表中最大索引小于列表最小索引 2.确保索引不是负数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式