oracle的executereader,尝试使用Oracle Data Access ODP.NET 11.2执行ExecuteReader()时出现InvalidOperationExceptio...

这是我第一次与Oracle合作,而且我们都讨厌在你使用特定模型的同时使用外国产品,尽管这是我们的工作,我们必须做到.

现在我已经安装了Oracle 11g,并复制并引用了Oracle.DataAccess.dll,创建了一个方法,用于打开连接并尝试从服务器上创建的视图中检索某些对象.

方法:

public BindingList GetHeaderReceivers()

{

try

{

using (OracleConnection db = new OracleConnection(BaseDataAccess.ConnString))

{

string cmdText = "select * from p_customer t";

BindingList headerReceivers = new BindingList();

OracleCommand cmd = new OracleCommand(cmdText) { CommandType = CommandType.Text };

db.Open();

OracleDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);

while (reader.Read())

headerReceivers.Add(HeaderReceiver.GetInstance(reader));

CustBranchRepository rep = new CustBranchRepository();

headerReceivers.ForEach(p => p.DetailsBranch = rep.GetDetailReceivers(p.Id));

reader.Close();

db.Close();

return headerReceivers;

}

}

catch (Exception ex)

{

ExporterLogger.Log(ex);

return null;

}

}

现在,当ExecuteReader()提交时,我得到了这个InvalidOperationException.

Operation is not valid due to the current state of the object.

StackTrace:

at Oracle.DataAccess.Client.OracleCommand.ExecuteReader(Boolean requery, Boolean fillRequest, CommandBehavior behavior)

at Oracle.DataAccess.Client.OracleCommand.ExecuteReader(CommandBehavior behavior)

at Exporter.Boss.DataAccess.CustomerRepository.GetHeaderReceivers() in ...Exporter\Exporter.Boss.DataAccess\CustomerRepository.cs:line 25

任何想法和帮助......

谢谢!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值