关于access数据库datareader对象的遍历
问题描述:
数据库表名: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)