关于access数据库datareader对象的遍历

lovingdxj 2009-11-25 11:08:20
问题描述:
数据库表名:11
数据库字段:ghddmi(形式如-100-4A)
要求去掉字段guddmi的最后一个字母(所有字段都为数字+一个字母)
并选出不重复的数据装入datareader对象,然后遍历

代码如下:
public partial class Print1 : System.Web.UI.Page
{
string hhtml = null;
protected void Page_Load(object sender, EventArgs e)
{
DataExe DataBase = new DataExe();//DataExe是自己写的一个数据库操作类,应该没有什么问题
string sqlstring = "select left(ghddmi,len(ghddmi)-1) as gg from 11";//sql语句就是用这个语句会出错
//string sqlstring = "select ghddmi from 11";//用这个的时候不会出错
OleDbDataReader dr1;
dr1 = DataBase.GetDataReader(sqlstring);
if (dr1 != null)
{
while (dr1.Read())
{

hhtml += dr1[0];//出错的提示在这,用dr["gg"]也是不行。。错误描述在下面
}
lblhtml.Text = hhtml;
}
else
{
lblhtml.Text = "系统错误!";
}

}
}

错误描述:
多步 OLE DB 操作产生错误。如果可能,请检查每个 OLE DB 状态值。没有工作被完成。
无效的过程调用

异常详细信息:
用户代码未处理 System.Data.OleDb.OleDbException
Message="多步 OLE DB 操作产生错误。如果可能,请检查每个 OLE DB 状态值。没有工作被完成。\r\n无效的过程调用"
Source="Microsoft JET Database Engine"
ErrorCode=-2147217887
StackTrace:
在 System.Data.OleDb.OleDbDataReader.ProcessResults(OleDbHResult hr)
在 System.Data.OleDb.OleDbDataReader.GetRowDataFromHandle()
在 System.Data.OleDb.OleDbDataReader.GetValueBinding(MetaData info)
在 System.Data.OleDb.OleDbDataReader.GetColumnBinding(Int32 ordinal)
在 System.Data.OleDb.OleDbDataReader.GetValue(Int32 ordinal)
在 System.Data.OleDb.OleDbDataReader.get_Item(Int32 index)
在 Print1.Page_Load(Object sender, EventArgs e) 位置 d:\学习\报表\Print1.aspx.cs:行号 29
在 System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e)
在 System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e)
在 System.Web.UI.Control.OnLoad(EventArgs e)
在 System.Web.UI.Control.LoadRecursive()
在 System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)

...全文
251 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenhaoying 2009-11-26
  • 打赏
  • 举报
回复
没看明白。是字段名去除还是数据去除最后一个字符?可以先读出来后再去除啊。
string sqlstring = "select ghddmi from 11";
然后用c#去除dr1[0].tostring(); 的最后一个字符啊,去除前判断一下是否为空。
lovingdxj 2009-11-26
  • 打赏
  • 举报
回复
hhtml += dr1[0].tostring();
是这里吗?我试过了不行啊。。。
大飞飞虫 2009-11-26
  • 打赏
  • 举报
回复
tostring一下
lovingdxj 2009-11-26
  • 打赏
  • 举报
回复
是去除数据里的最后一个字符,因为ghddmi这个字段下的数据有-100-4A,-100-4B,-100-4D,要求将最后一个字母去掉后取出不重复的数据。。所以要在查询的时候去除掉。然后用distinct 去除重复。。

select distinct left(ghddmi,len(ghddmi)-1) as gg from 11
应该是这个,我只是用上面的先试验下。。
但是一直出错。

62,254

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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