当创建多个DataReader对象.时,系统将提示“已有打开的与此连接相关联的DataReader,必须首先将它关闭,并不是我想多创建几个这样的对象,只因数据是按树状结构分布的,通过递归来完成数据的访问,所以才会出现多个DataReader的情况,我把问题分析有如下几种可能性:
1.数据库本身的限制,这种情况不可能,我在ASP中采用的ODBC访问,没出现问题,转到.NET时才出现这样的情况。
2.我用的连接或相关的对象存在相应的属性设置,这种情况倒是有可能,但我无资料可查,通过属性浏览也没有看到可能的属性对象。
3..NET本身的BUG,这种可能性也是很大的,一般的对象的默认情况应该能够正常操作,通过限制来达到其他其他相关需求,如安全性等。
所以我把源码列出来,让大家帮个忙,有没有解决的办法,示例代码用的是ODBC,原先用的是SqlClient,结果都是一样的。
using System;
using System.Data ;
using System.Data .Odbc ;
namespace ConsoleApplication1
{
/// <summary>
/// Class1 的摘要说明。
/// </summary>
class Class1
{
public OdbcConnection Conn;
/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main(string[] args)
{
//
// TODO: 在此处添加代码以启动应用程序
//
new Class1 ().Do ();
}
public void Do()
{
// 在此处放置用户代码以初始化页面
//打开数据库连接
Conn = new OdbcConnection ("DSN=AMGDM3_SQL;uid=sa;pwd=;");
Conn.Open ();
if(Conn.State == ConnectionState .Closed )
{
//无法连接数据库服务器
Console.WriteLine ("数据库服务器已经关闭,暂停服务。");
return;
}
string strSQL = "SELECT * FROM FILE_DIRECTORY WHERE CLASS=0 AND PID=0";
OdbcDataAdapter adapter = new OdbcDataAdapter (strSQL , Conn);
ShowDirectory(adapter , "person" , Conn , 0);
}
public void ShowDirectory(OdbcDataAdapter adapter , string strId , OdbcConnection conn , int nType)
{
OdbcDataReader reader = adapter.SelectCommand .ExecuteReader ();
if(reader.HasRows )
{
while(reader.Read ())
{
if(ExistChildNode((string)reader["Id"].ToString () , conn , true))
{
Console.WriteLine (string.Format ("dir{0}=insFld({1},gFld(\"{2}\",\"" , reader["Id"] , strId , reader["DirName"]));
}
else
{
Console.WriteLine (string.Format ("dir{0}=insDoc({1},gLnk(0,\"{2}\",\"" , reader["Id"] , strId , reader["DirName"]));
}
Console.WriteLine ("main.asp?DicType=Dir");
Console.WriteLine (string.Format ("&Id={0}\"))\r\n" , reader["Id"]));
string strSQL;
strSQL = string.Format ("SELECT * FROM FILE_DIRECTORY WHERE PID={0}" , reader["Id"]);
OdbcDataAdapter adapter2 = new OdbcDataAdapter (strSQL , conn);
ShowDirectory(adapter2 , string.Format ("dir{0}" , reader["Id"]) , conn , nType);
}
}
reader.Close ();
}
private bool ExistChildNode(string strDeptId , OdbcConnection conn , bool bDept)
{
return true;
}
}
}