Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6229813
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T09:38:18+00:00 2026-05-24T09:38:18+00:00

In our application, during save operation we are data to almost 15 child tables.

  • 0

In our application, during save operation we are data to almost 15 child tables. When some error occurred, we have data discrepancy in tables. So we decided to use TransactionScope. When we use that it gives error saying “Transaction has aborted”, StackTrace display following.

 at System.Transactions.TransactionStateAborted.BeginCommit(InternalTransaction tx, Boolean asyncCommit, AsyncCallback asyncCallback, Object asyncState)
   at System.Transactions.CommittableTransaction.Commit()
   at System.Transactions.TransactionScope.InternalDispose()
   at System.Transactions.TransactionScope.Dispose()

Our code looks like

using (TransactionScope tScope = new TransactionScope())
                {
                    dataManager.AddFood(food);
                    if (!ModelState.IsValid)
                        throw new ApplicationException("Model state is invalid");
                    if (beingCloned)
                        food.IsUserFood = false;



                dataManager.Save();
                if (!food.IsUserFood)
                    dataManager.GenerateSearchRecords(food.FoodID);

                FoodManager foodManager = new FoodManager();
                foodManager.CopyFoodToHistory(food);

                if (beingCloned)
                {
                    foodManager.CreateUserFoodCopyForClonedFood(food);
                    HttpPostedFileBase file = ControllerContext.HttpContext.Request.Files["Image"];

                    if (file != null && file.FileName.Length > 0)
                        foodManager.UpdateMediaCopyForClonedFood(food, true);
                    else
                        foodManager.UpdateMediaCopyForClonedFood(food);
                }
                tScope.Complete();
            }

Thanks in advance

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T09:38:19+00:00Added an answer on May 24, 2026 at 9:38 am

    TransactionScope can be used with multiple DataContexts, but as soon
    as more than one connection is involved the transaction is escalated
    to a MSDTC/XA/distributed transaction. For that to work you need to
    have MSDTC running on both the system where you code runs and on the
    database server.

    Alternatively, you can avoid escalation to a distributed transaction
    if you create an explicit connection within the transactionscope and
    pass that to your datacontexts; that way the TransactionScope will not
    escalate to a distributed transaction, and won’t rely on MSDTC…

    https://stackoverflow.com/a/1592133/102937

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

found a interesting problem during testing our web application. I have application on localhost
I have a query In our application we have lots of HTML tags. During
During the course of our application login there are several queries ran, all around
Our application is interfacing with a lot of web services these days. We have
Our application is well structured (well we did our best!) and we have split
Our application is written in C++ and used on Windows XP. On some client
We have a Spring application that uses Apache DBCP for connection pooling. Our app
Our product team has requested custom cursors during drag/drop operations. They have provided me
For our application, we keep large amounts of data indexed by three integer columns
Context: We have some users reporting issues with a file upload feature in our

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.