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 4615928
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 22, 20262026-05-22T01:54:36+00:00 2026-05-22T01:54:36+00:00

I have made this post over a year ago, and I think it makes

  • 0

I have made this post over a year ago, and I think it makes sense to update it as it’s getting quite a few views.

I’m either missing something out or Microsoft has really messed up MVC. I worked on Java MVC projects and they were clean and simple. This is however a complete mess IMO. Examples online such as NerdDinner and projects discussed on ASP.Net are too basic, hence why they “simply” work. Excuse if this sounds negative, but this is my experience so far.

I have a repository and a service that speaks to the repository. Controllers call service.

My data layer is NOT persistence independent, as the classes were generated by SQL metal. Because of this I have a lot of unnecessary functionality. Ideally I’d like to have POCO, but I didn’t find a good way to achieve this yet.

*Update: Of course Microsoft hasn’t messed anything up – I did. I didn’t fully understand the tools that were at my disposal. The major flaw in what I have done, was that I have chosen a wrong technology for persisting my entities. LINQ to SQL works well in stateful applications as the data context can be easily tracked. However, this is not a case in stateless context. What would be the right choice? Entity Framework code first or code only work pretty well, but what’s more importantly, is that it shouldn’t matter. MVC, or front end applications must should not aware of how data is persisted. *

When creating entites I can use object binding:

[HttpPost]
public ActionResult Create(Customer c)
{
    // Persistance logic and return view
}    

This works great, MVC does some binding behind the scene and everything is “jolly good”.

It wasn’t “Jolly Good”. Customer was a domain model, and what was worse, it was dependent on persistence medium, because it was generated by SQL metal. What I would do now, is design my domain model, which would be independent of data storage or presentation layers. I would then create view model from my domain model and use that instead.

As soon as I’d like to do some more complex, e.g. – save Order which is linked to the customer everything seems to break:

    [HttpPost]
    public ActionResult Create(Order o)
    {
        // Persistance logic and return view
    }

To persist an order I need Customer or at least CustomerId. CustomerId was present in the view, but by the time it has got to Create method, it has lost CustomerId. I don’t fancy sitting around debugging MVC code as I won’t be able to change it in a hosting envrionment either way.

Ok, a bit of moaning here, sorry. What I would do now, is create a view model called NewOrder, or SaveOrder, or EditOrder depending on what I’m trying to achieve. This view model would contain all the properties that I’m interested in. Out-of-the-box auto binding, as the name implies, will bind submitted values and nothing will be lost. If I want custom behaviour, then I can implement my own “binding” and it will do the job.

Alternative is to use FormCollection:

[HttpPost]
public ActionResult Create(FormCollection collection)
{
   // Here I use the "magic" UpdateModel method which sometimes works and sometimes doesn't, at least for LINQ Entities.               
}

This is used in books and tutorials, but I don’t see a point in a method which has an alternative: TryUpdateModel – if this crashes or model is invalid, it attempts to update it either way. How can you be certain that this is going to work?

Autobinding with view models will work the most of the time. If it doesn’t, then you can override it. How do you know it will always work? You unit test it and you sleep well.

Another approach that I have tried is using ViewModel – wrapper objects with validation rules. This sounds like a good idea, except that I don’t want to add annotations to Entity classes. This approach is great for displaying the data, but what do you do when it comes to writing data?

[HttpPost]
public ActionResult Create(CustomViewWrapper submittedObject)
{
    // Here I'd have to manually iterate through fields in submittedObject, map it to my Entities, and then, eventually, submit it to the service/repository.
}    

** View model is a good way forward. There would have to be some mapping code from view model to the domain model, which can then be passed to the relevant service. This is not a correct way, but it’s one way of doing it. Auto mapping tools are you best friends and you should find the one that suits your requirements, otherwise you’ll be writing tons of boilerplate code.**

Am I missing something out or is this the way Microsoft MVC3 should work? I don’t see how this is simplifying things, especiialy in comparisson to Java MVC.

I’m sorry if this sounds negative, but this has been my experience so far. I appreciate the fact that the framework is constantly being improved, methods like UpdateModel get introduced, but where is the documentation? Maybe it’s time to stop and think for a little bit? I prefer my code to be consistent throughout, but with what I have seen so far, I have no confidence whatsoever that this is a right way forward.

I love the framework. There is so much to learn and it’s not a lot more exciting then it has ever been. Should probably make another post regarding web forms. I hope this is helpful.

  • 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-22T01:54:37+00:00Added an answer on May 22, 2026 at 1:54 am

    I don’t think your issue is with asp.net MVC but with all the pieces You Choose to use together.

    You want it raw and simple?

    Use POCOs all around, and implement the repository where you need it.

    I haven’t used Java MVC, but it’d make the whole question look less like a rant if you include how you solved the particular problem in there.

    Let’s clear some misconceptions or maybe miscommunication:

    • You can pass complex objects through a post to the view. But you only want to do so if it makes sense, see next bullet
    • The sample you picked there rings some alarms. Accepting Customer data or CustomerID for an order and not checking authorization can be a Big security hole. The same could be said for an Order depending on what you are accepting/allowing. This is a Huge case for the use of ViewModels, regardless of POCOs, LINQ, Asp.net MVC or Java MVC.
    • You can pass simple values not being showed through a post to the view. It’s done with hidden fields (which asp.net MVC supports very simply to use the model value), and in some scenarios it generates the hidden fields for you.
    • You are in no way forced to use linq2sql with Asp.net MVC. If you find it lacking for how you intend to use it, move away from it. Note I love linq2sql, but how it is tied to your view of what you can do with asp.net mvc is weird.
    • ” I worked on Java MVC projects and they were clean and simple”. Working on a project is not the same as designing the project yourself. Design skills does affect what you get out of anything. Not saying is your case, but just wanted to point that out given the lack of specifics on what you’re missing from Java MVC.
    • “My data layer is NOT persistence independent, as the classes were generated by SQL metal. Because of this I have a lot of unnecessary functionality. Ideally I’d like to have POCO, but I didn’t find a good way to achieve this yet”. You picked the wrong technology, linq2sql is Not meant to fit that requirement. It haven’t been a problem in the projects I’ve used it, but everything is designed in such a way that way less tied to its specifics than you seem to be. That said, just move to something else. btw, You should have shared what you used with Java MVC.
    • “CustomerId was present in the view, but by the time it has got to Create method, it has lost CustomerId.” If the property is in Order, You can bet your code has the bug. Now, that’d have been a totally different Real question, why it isn’t using the CustomerId / such question would come with: your Customer class, the View, what you are passing to the View … answers would include, but not be limited to: inspect the HTML source in the browser to see what value you are really posting with the source (alternatively use fiddler to see the same), make sure that CustomerId really has the value when you pass it to the View.
    • You said: “”magic” UpdateModel method which sometimes works and sometimes doesn’t”. It’s not magic, you can see what it does and certainly find information on it. Something is off in the information you are posting, my bet is non optional fields or wrong values for information that’s parsed … views support adding validations for that. Without the validations, this can be lacking.
    • You said in a comment: “After UpdateModel is called, i can’t explicitly set the CustomerId, I’ll have to retrieve a customer object and then assign it to the order, which seems like an overhead as all that I need is CustomerId” … you are accepting a CustomerId that is user input (even if it is a hidden field), you really want to Validate that input. Additionally you are contradicting yourself, you claim to just need CustomerId, but then you say you need the full Customer Object related to the order bound. Which is it, if you are only binding the CustomerId, you still need to go get that Customer and assign it to the property. There is no magic besides the scenes …
    • Also in a comment: “Update model is something I’m avoiding completely now as I don’t know how it will behave with LINQ entities. In the view model class I have created constructor that converts LINQ entity to my view model. This decreased amount of code in controller, but still doesn’t feel right”. Reason to use ViewModel (or EditModel) is not because it is linq2sql … it is because, among many other reasons, you are exposing a model that allows to manipulate way beyond what you actually want to allow the user to modify. Exposing the raw model, if it has fields the user shouldn’t be allowed to modify, is the real issue.
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Since I'm sure many people have different standard, I've made this post a community
I have made this mistake several times, and found myself referencing This Post every
I have roughly the following code. Could this be made nicer or more efficient?
Coming from this question , I have a wxComboCtrl with a custom popup made
This is the day of weird behavior. We have a Win32 project made with
I have made a SVG image, or more like mini application, for viewing graphs
I have made some code which exports some details of a journal article to
I have made a custom UserControl i Vb.net (windows application). How can I add
I have made a little app for signing up for an event. User input
I have made a program in c and wanted to see, how much memory

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.