读取器关闭时无效尝试调用Read。得到这个错误?

时间:2014-03-12 10:32:42

标签: c# ado.net

读取器关闭时无效尝试调用Read。用c#获取此错误的asp.net? 我使用过这段代码

string catalogNo = string.Empty;
string deleteID = string.Empty;  
Globals.Initialize("Text", "select CatelogNo,DeleteID from tbl_admin_quotation where QuotationID='" + quotation3 + "' order by id asc");
Globals.dr = Globals.cmd.ExecuteReader();
while (Globals.dr.Read() == true)
{
    catalogNo = Globals.dr[0].ToString();
    deleteID = Globals.dr[1].ToString();
    decimal taqty = 0;
    Globals.Initialize("Text", "select qty from tbl_admin_quotation where DeleteID='" + deleteID + "'");
    Globals.dr3 = Globals.cmd.ExecuteReader();
    if (Globals.dr3.Read() == true)
    {
        taqty = Convert.ToDecimal(Globals.dr3[0].ToString());
    }
    Globals.dr3.Dispose();
    Globals.dr3.Close();
    Globals.Initialize("Text", "select Pqty,Hqty from  tbl_admin_stock where CatelogNo='" + catalogNo + "'");
    Globals.dr = Globals.cmd.ExecuteReader();
    if (Globals.dr.Read() == true)
    {
        if (Convert.ToDecimal(Globals.dr[0].ToString()) != 0)
        {
            Globals.Initialize("Text", "update tbl_admin_stock set Pqty=Pqty+'" + Convert.ToDecimal(taqty) + "' where CatelogNo='" + catalogNo + "'");
            Globals.cmd.ExecuteNonQuery();
        }
        else if (Convert.ToDecimal(Globals.dr[1].ToString()) != 0)
        {
            Globals.Initialize("Text", "update tbl_admin_stock set Hqty=Hqty-'" + Convert.ToDecimal(taqty) + "' where CatelogNo='" + catalogNo + "'");
            Globals.cmd.ExecuteNonQuery();
        }
    }
    Globals.dr.Dispose();
    Globals.dr.Close();
}

  Globals.dr.Dispose();
Globals.dr.Close(); 
 Globals.Initialize("Text", "delete from tbl_admin_quotation where  QuotationId=@QuotationId");
Globals.cmd.Parameters.AddWithValue("@QuotationId", quotation3);
Globals.cmd.ExecuteNonQuery();

UpdatePanelMain.Update();
GridviewBind();

1 个答案:

答案 0 :(得分:0)

如果你的代码中有明显的问题和问题你找不到,先解决明显的问题然后隐藏的问题可能会变得很明显:

摆脱全局垃圾并将using放在适当的位置,然后从中调用Dispose()而不是明确地解决这个问题。