I have just finished reading an article on MSDN by John Evdemon. He bashes the CRUD interfaces and calls it an anti-pattern.
While I agree that having ANYTHING stateful is difficult and Current and MoveNext are bad ideas I don't agree that CRUD as in Create Read Update and Delete are bad. If I have a car service and I want to let clients be able to do the basics, as in Create a car, get a cars details, update a cars details or delete a car then how are they meant to be able to do those things without CRUD operations.
Or what am I missing here?
While REST is the most widely considered design style for Web APIs, CRUD helps in database applications. As organizations use REST API, they inherently rely on a RESTful Architecture. However, REST and CRUD operations resemble each other because REST is a superset of CRUD when performing HTTP methods.
In its base form, CRUD is a way of manipulating information, describing the function of an application. REST is controlling data through HTTP commands. It is a way of creating, modifying, and deleting information for the user. CRUD functions can exist in a REST API, but REST APIs are not limited to CRUD functions.
CRUD Meaning: CRUD is an acronym that comes from the world of computer programming and refers to the four functions that are considered necessary to implement a persistent storage application: create, read, update and delete.
In full-fledged applications, CRUD apps consist of 3 parts: an API (or server), a database, and a user interface (UI). The API contains the code and methods, the database stores and helps the user retrieve the information, while the user interface helps users interact with the app.
The CRUD interfaces should be avoided in distributed system / SOA scenario because they are very chatty. But should doesn't mean have to. When you have some client actions which require more than one call to your service then you know that you should give up CRUD approach and create new service operation which will agregate those calls into single call. When designing distributed system you should always reduce number of calls to minimum because network call is very time consuming.
Edit:
You can think about CRUD interface as about data access exposed in a service. Sometimes you really want this. But in SOA and distributed system architecture you are usually exposing business functionality which already wraps data access and offers much more complex operations (which agregate many data access operations).
Example:
CRUD x Business logic interface. Suppose that you are working with Invoices
. Each invoice consists of an InvoiceHeader
and one or more InvoiceLine
. If you use a CRUD interface for invoice you will first call CreateInvoiceHeader
operation to create InvoiceHeader
and then several AddInvoiceLine
operations to add all InvoiceLines
- that is low level CRUD approach. But if you implement business logic on the service side you will call single CreateInvoice
and pass a complex object graph (header with all lines) to the service to create and add what is needed. The Create
method can also do other business operations like starting some workflow etc. That is common SOA and distributed system approach.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With