|
Posted by NC on 03/13/06 06:40
Richard Levasseur wrote:
>
> What abstraction layers lose in performance (which is miniscule,
> for the most part), they gain in ease of use, portability, and
> maintainability.
I respectfully disagree.
Ease of use is a matter of opinion; what is easy to me is not
necessarily easy to you and vice versa. Our discussion is the case in
point; you think it is possible to simplify database access by
introducing an abstraction layer, while I think that calls to native
API functions are simple enough... :)
Portability (if, in the context of this discussion, we define it as the
application's ability to use multiple database engines) and
maintainability are conflicting goals -- maintainability decreases with
the size of code base, while portability requires expansion of the code
base, so portable applications are by definition more difficult to
maintain. Code that does not rely on abstraction layers is by
definition more maintenable, simply because developers don't have to
maintain the abstraction layers themselves.
Loss of performance, however, is objectively measurable and LARGE (at
least, that's what phpLens benchmarks show, and, to the best of my
knowledge, no one has produced a benchmark test with markedly different
results). There is no evidence that points to "miniscule" performance
losses you spoke of; the evidence suggests that the losses are
substantial. If you are aware of any benchmarks that support your
claim, please share your knowledge, and I will happily reconsider my
position.
Cheers,
NC
[Back to original message]
|