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

  • SEARCH
  • Home
  • 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 7848749
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 2, 20262026-06-02T18:18:58+00:00 2026-06-02T18:18:58+00:00

Given an MVC3 app using the ViewModel pattern and the Repository pattern with Entity

  • 0

Given an MVC3 app using the ViewModel pattern and the Repository pattern with Entity Framework.

If I have a create and update view each composed of multiple entities,  what is the best practice for saving the data?

Should I save the date using an abstracted service layer which will save the data for each entity with its respective repository or should I save the data in the repository using a stored procedure?

I’m open to any suggestions or recommendations.

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-06-02T18:18:59+00:00Added an answer on June 2, 2026 at 6:18 pm

    This is one of those cases where a DDD/CQRS approach makes most sense. Simply put, you have some business objects which models a specific behavior (an aggregate). There is one object in chrage called the Aggregate Root (AR) which has explicit boundaries. When you want to save it, you send the whole AR to the repository which then saves everything as a transaction.

    The workflow

    User sends the data via a view model. The controller will then retrieve the AR from the repository or creates if it’s new . THe input data is mapped to the AR, usually via an AR method. IF the AR finds that the data or the result of it, breaks some business rules then it should throw an exception (we assume that basic validation was already performed automatically by asp.net mvc).

    If everything is ok, the controller will send the AR to the repo which then it will proceed to map the AR to EF entities and then saves it, all within a transaction.

    THis is in a nutshell how I’d do it. Of course, I’d actually implement it a bit different, but the concepts are the same. THe important part is to send all the data to the AR which will know how to handle relationships.

    Important points

    Note that I’ve mentioned EF only after the AR got to the repo. This means, the AR has no relation to EF entities is completely separated and serves the actually business model. Only after the model is updated, we care about EF and ONLY within the repo (because EF is an implementation detail of the repo). The repo only transfers (maps basically) AR data to the relevant EF entities and then saves the entities.

    It’s important to have a very clear distinction between the business (domain) model and the persistence modewl (EF entities). Don’t use EF to handle business rules, use it only to stare/retrieve data from db. EF was made to abstract RDBMS access only, use it as a virtual OOP database.

    You’ve mentioned the ViewModel pattern. I haven’t heard about such a pattern, everytime you’re using MVC you’re already using ViewModels. One again, the trick is NOT to use EF entities as ViewModels. Use ‘dumb’ view models fitted for the views. Populate the VM via a specialized Queries repository which will return directly VM parts. The repo will query EF entities and then return those VM bits which are simple DTO’s. That’s because you don’t need validation and business rules when showing data.

    I think it is a good practice to keep the layers and especially each layer’s model separated. For updating stuff, use complex business objects(domain model) which will do the hard work and then only transfer their state to EF (via repository). For reading stuff, query EF and return simple DTOs fit for VM.

    This is what CQRS is really about: don’t try to fit different responsibilities (write and read) in a single model.

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

Sidebar

Related Questions

I am trying to create a web app using ASP.Net MVC3, Entity Framework and
I have an MVC3 web app to which I want to start using whole
I am building a .NET 4.0 MVC3 app. I use Entity Framework 4.1 and
Scenario: An MVC3 app that uses constructor injection to provide services for a given
I have an MVC3 C#.Net web app. I have the below string array. public
I have written a little bog standard asp.net mvc3 app in vs web express
Using MVC3.NET I have a file upload method in a controller that works fine
I am using MVC3 and I want to have LogIn form and Register form
I'm confused by this behavior: I have an out-of-the-box MVC3 app. I haven't really
I have created my first app for azure. It's has an MVC3 web role

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.