SqlException on Commit () Операция транзакции не может быть выполнена, потому что есть ожидающие запросы, работающие над этой транзакцией - PullRequest
0 голосов
/ 12 сентября 2018

Моя транзакция SQL выдает исключение на Commit (). Это первый раз, когда я использую транзакции с SqlCommands, так что, возможно, я делаю некоторые ошибки в коде. Я видел другие вопросы относительно той же ошибки, но ни один из них не помог. Я попытался явно вызвать Close () для reader , но безрезультатно.

using (var selectModifiedCmd = new SqlCommand(selectModified, conn, trans))
                {
                    try
                    {
                        decimal qty, qtyPerUOM, weight, weightKg;
                        string no, binCode, binText, shelfNo, mainZone, sourceTu, destNo, cluster;
                        int lineNo, corridor, sortAsc, sortDesc, rowOrder;
                        short pricePerKg;

                        using (var reader = selectModifiedCmd.ExecuteReader())
                        {
                            while (reader.Read())
                            {
                               ........

                                using (var updateModifiedCmd = new SqlCommand(updateModified, conn, trans))
                                {
                                    ........

                                    updateModifiedCmd.ExecuteNonQuery();
                                }

                                using (var returnModifiedCmd = new SqlCommand(returnModified, conn, trans))
                                {
                                    returnModifiedCmd.Parameters.AddWithValue("no", no);
                                    returnModifiedCmd.Parameters.AddWithValue("lineNo", lineNo);

                                    returnModifiedCmd.ExecuteNonQuery();
                                }

                                trans.Commit();

                                Globals.WriteLog(MethodBase.GetCurrentMethod().Name, String.Format(logSuccess, no, lineNo, binCode, qty));
                            }
                        }
                    }
                    catch (SqlException ex)
                    {
                        var trace = new StackTrace(ex, true);
                        Globals.WriteLog(
                            MethodBase.GetCurrentMethod().Name,
                            ex.Message + " At line: " + trace.GetFrame(trace.FrameCount - 1).GetFileLineNumber());

                        try
                        {
                            trans.Rollback();
                        }
                        catch (Exception exRollback)
                        {
                            Globals.WriteLog("Rollback error: ", exRollback.Message);
                        }
                    }
                }
...