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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T13:34:03+00:00 2026-06-13T13:34:03+00:00

I am looking at OData and it is very powerful, at the same time

  • 0

I am looking at OData and it is very powerful, at the same time it’s very disconcerting. It is the equivalent of exposing your datasource to a remote user. There is no service nothing nada and very little injection points, resulting in an almost comical 2-tier architecture.

My concerns are:

  1. It’s hard to enforce pattern such as DDD while using OData.

  2. It is also hard to use OData against a set of soa Data Transfer Objects, because these are not usually queryable. ie.by the time you get the DTOs, the DB query is done, but OData is just starting up. There is not a lot of value in querying against it, because the DTOs are already in memory.

  3. I can create a view on the DB itself that’s a representation of the OData entity, but this is putting UI concern in persistence. Big no-no.

  4. At best combining the result set from various DDD services now happens at the UI layer using kludgy javascipt – a maintainance nightmare with poor reuseability record.

  5. Another possibility is to write a translator for the OData entity which is likely a ViewModel level class, that then translates to the DTOs, that then translates to Domains, that then translates to the ConceptualModels, the rest the ORM can handle. But this will require an inordinate amount of resources.

In short, how do you make OData play nice with SOA, OO encapsulation principles, DDD and just good old SOC?

  • 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-13T13:34:04+00:00Added an answer on June 13, 2026 at 1:34 pm

    There needs to be clear separation of the OData standard and the OData implementations.

    As for the standard:

    The standard itself to my view lets you to have an OOTB accessible data endpoint with full metadata on a portable manner. With support for relations and projection consumers can compose viewmodels on the server or later on the client. It is important to note, that OData supports operations (functions) to be exposed, so on the top of automatic crud you can have remote methods that seamlessly integrate into the relational pattern (functions can have results that you can further query, still on the server, and also functions can act as the “smart writer” code).

    To wrap it up: OData gives a shape to what actually happens most of the time when someone needs massive REST compliant data access: formalizes common, always repeated scenarios like how it is to query for data or submit data back. This might be still affected by what you write at point 4, but to my opinion it’s not an OData related issue. This is simply how AJAX and Mashups work: you’ll have a client with lots of code dealing with combining data.

    Other issues of yours can be answered with selecting the most appropriate server implementation. There are a couple of implementations already:

    • EF4/EF5 + WCF Data Services being the most “automatic”. In this use case you might just be correct regarding some of your concerns but: with the fine extensibility model of EF you can interact with the automatic operations as you wish. Having an application that is driven by the actual EDMX model is a true DDD scenario.

    • ASP.NET Web API let’s you have a totally code based back-end for what you perceive as a static, relational endpoint, so this is where you can think in 3 layers: DB, middle tier to bridge between DB data and to what is best for the clients, and client tier as a smart consumer to that model.

    • JayData provides these in Server Side JavaScript with the added dynamism of JavaScript.

    • SAP NetWeaver gateway exposes complex SAP data on a manner easy to consume for simple scenarios.

    OO concerns:
    With V3 of OData we have now “instance methods” (that are definitely server methods too) so what actually SOA took away with brutally separating things to data and functionality OData really gives back: defining functionality + data encapsulated but in mapped to the SOA concept of static methods with context data that act like the "this".

    2Tier concerns:
    IMHO 2Tier architectures became “ancient” not because the client has too much knowledge about the server side structure, but because they did not scale well and the new thin cliens were to dumb to act like a real DB client. In fact 2tier was always easier to work with (from a developer point of view), and now that actually OData server implementations are indeed middle tier with logic, you actually can get the best of both worlds:
    – code agains a virtuall 2 tier architecture
    – and scale as a normal n tier application can.

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

Sidebar

Related Questions

I am looking for an OData wrapper in C# that can talk to any
Im looking for a script that will take OData feed and download some .wmv
Looking for a control that allows to select one text value at a time
I'm trying to ask my OData service: Give me all the Products that do
Looking for web service that download a webpage (we'll provide the URL), normalize it
I am very new to OData (only started on it yesterday) so please excuse
Looking for an equivalent container class that matches to C#'s Arraylist collections class. Is
Looking for simple php class routing, like this: http://fatfree.sourceforge.net/page/routing-engine Is there a ready-made solutions?
I am very new do both Facebook insight and to OData. I am new
Looking for any recent examples using OAuth with OData pref. from a WPF client

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.