Транзакции в LINQ To SQL - PullRequest
       43

Транзакции в LINQ To SQL

2 голосов
/ 14 августа 2010

Я использую LINQ To SQL и вызываю хранимые процедуры для добавления новых строк.

  1. Показывает ли приведенный ниже код соответствующий набор шагов?
  2. Я хочу вставить (остальные четверки), только если все четыре вставки пропущены, в противном случае откатите все четыре вставки.
public bool InsertNewInquiry(Inquiry inq)
{
    using (var transaction = new TransactionScope())
    {
        using (DataContextDataContext dc = conn.GetContext())
        { 
            foreach (Officer po in inq.Recipients)
            {
                int results1 =  (int)dc.**spOffice_Insert**(po.Id,po.Name).ReturnValue;
            }
            foreach (Lookups tags in inq.Tags)
            {
                int results2 =  (int)dc.**spTags_Insert**(po.Id,po.Name).ReturnValue;
            }

            foreach (Phone phone in inq.Phone)
            {
                int results3 =  (int)dc.**spPhone_Insert**(po.Id,po.Name).ReturnValue;
            }

            int results4 =  (int)dc.spInquiry_Insert(
                            inq.Id
                            ,inq.StatusId
                            ,inq.PriorityId
                            ,inq.Subject).ReturnValue;                  


          if (results1 != 0 && results2 != 0 && results3 != 0 && results4 != 0)
          {
              transaction.Complete();
              return true;
          }
          return false;

           /* old code:
            transaction.Complete();    
            if (results == 0)
                return false;
            else
                return true;  */
        }
    }
}

Я пробовал приведенный выше код, но он не вставляет вставку foreach (результаты1 ... результаты3)

Есть идеи, как я могу заставить эту работу работать по желанию?

Ответы [ 3 ]

1 голос
/ 17 августа 2010

Рассмотрим решение, где:

  • изменить область ваших результатов
  • , если 0 результат - условие для любого из ваших 3 foreach , для которого вы абсолютно хотите откатиться, не увеличивайте, как показано ниже. Просто проверьте 0 и break вне пределов foreach.
int res1=0, res2=0, res3=0, res4=0;
foreach (Officer po in inq.Recipients)
{
    res1 += (int)dc.**spOffice_Insert**(po.Id,po.Name).ReturnValue;
}
foreach (Lookups tags in inq.Tags)
{
    res2 += (int)dc.**spTags_Insert**(po.Id,po.Name).ReturnValue;
}
foreach (Phone phone in inq.Phone)
{
    res3 += (int)dc.**spPhone_Insert**(po.Id,po.Name).ReturnValue;
}
res4 += (int)dc.spInquiry_Insert(inq.Id,inq.StatusId,inq.PriorityId,inq.Subject)
                 .ReturnValue;                  

//no results are zero
if (res1 != 0 && res2 != 0 && res3 != 0 && res4 != 0)
{
    transaction.Complete();
    return true;
}
return false;
0 голосов
/ 14 августа 2010

TransactionScope это путь, по моему мнению. У меня был похожий вопрос относительно транзакций в Linq To SQL некоторое время назад. Хотя это не та проблема, ответы, которые я получил, должны предоставить вам некоторую полезную информацию.

Исходя из того, что я могу сказать из вашего кода, вы не учитывали четыре результата возврата до вызова transaction.Complete();. Оператор Complete() подтвердит вашу транзакцию, поэтому вы должны убедиться, что все правильно, прежде чем вызывать это так же, как в SQL * COMMIT.

0 голосов
/ 14 августа 2010

Проверьте этот пост , где TransactionScope и LinqToSQL используются вместе

...