研究员,
我正在使用ADODB命令从数据库中提取一些信息,该数据库由几个字段组成。但是,当我运行代码时,它只会拉出一个字段,而且它总是相同的。就我所知,我正在使用MoveNext,并且我在EOF while循环中嵌套。
这是我到目前为止所得到的:
if (!rsStbDetails.EOF)
{
while (!rsStbDetails.EOF)
{
foreach (ADODB.Field f in rsStbDetails.Fields)
{
if (f.Value == null)
{
f.Value = 0;
}
switch (f.Name)
{
// There's a load of case statements here to manipulate the values being read in
default:
SetValue(id, f.Name, f.Value, f.Position);
break;
}
}
}
rsStbDetails.MoveNext();
}
有什么想法吗? 干杯
编辑:这是我用来建立连接的代码:
objComm.ActiveConnection = conSQL;
objComm.CommandType = CommandTypeEnum.adCmdStoredProc;
objComm.CommandText = "Service.GetDetails";
objComm.Parameters.Append(objComm.CreateParameter("@Node", ADODB.DataTypeEnum.adVarChar, ParameterDirectionEnum.adParamInput, 50, "NAME"));
objComm.Parameters.Append(objComm.CreateParameter("@Box", ADODB.DataTypeEnum.adVarChar, ParameterDirectionEnum.adParamInput, 20, ""));
objComm.Parameters.Append(objComm.CreateParameter("@Num", ADODB.DataTypeEnum.adInteger, ParameterDirectionEnum.adParamInput, 20, 0));
objComm.Parameters.Append(objComm.CreateParameter("@Exclude", ADODB.DataTypeEnum.adInteger, ParameterDirectionEnum.adParamInput, 20, iExclude));
objComm.Parameters[1].Value = Right((string)GetProperty(id, "SName", role), 8);
答案 0 :(得分:2)
你应该至少移动rsStbDetails.MoveNext();
一个支撑:)
答案 1 :(得分:1)
在while循环中添加此行:rsStbDetails.MoveNext();
还有一件事,我建议您必须使用ADONet
技术,因为您处于.net
环境中。
<强> This link is a very good place to learn ADO NET
technology. 强>
答案 2 :(得分:0)
事实证明,问题是服务器端问题,与我的代码无关。我已经接受了Gerald的回答,指出错误的MoveNext()放置。无论如何,谢谢,伙计。