Data access object
In software, a data access object (DAO) is a pattern that provides an abstract interface to some type of database or other persistence mechanism. By mapping application calls to the persistence layer, the DAO provides data operations without exposing database details. This isolation supports the single responsibility principle. It separates the data access the application needs, in terms of domain-specific objects and data types (the DAO's public interface), from how these needs can be satisfied with a specific DBMS (the implementation of the DAO).
Although this design pattern is applicable to most programming languages, most software with persistence needs, and most databases, it is traditionally associated with Java EE applications and with relational databases (accessed via the JDBC API because of its origin in Sun Microsystems' best practice guidelines[1] "Core J2EE Patterns".
Advantages
The primary advantage of using data access objects is the rigorous separation between two parts of an application that have no need to know anything about each other, and which therefore can evolve frequently and independently. Changing business logic can rely on a constant DAO interface, while changes to persistence logic do not affect DAO clients.
All details of storage are hidden from the rest of the application (see information hiding). Unit testing code is facilitated by substituting a test double for the DAO in the test, thereby making the tests independent of the persistence layer.
In the context of the Java programming language, DAO can be implemented in various ways. This can range from a fairly simple interface that separates data access from the application logic, to frameworks and commercial products.
Technologies like Java Persistence API and Enterprise JavaBeans come built into application servers and can be used in applications that use a Java EE application server. Commercial products such as TopLink are available based on object–relational mapping (ORM). Popular open source ORM software includes Doctrine, Hibernate, iBATIS and JPA implementations such as Apache OpenJPA.
Disadvantages
Potential disadvantages of using DAO include leaky abstraction, code duplication, and abstraction inversion. In particular, the abstraction of the DAO as a regular Java object can obscure the high cost of each database access. Developers may inadvertently make multiple database queries to retrieve information that could be returned in a single operation. If an application requires multiple DAOs, the same create, read, update, and delete code may have to be written for each DAO.[2]
Tools and frameworks
- ODB compiler-based object–relational mapping (ORM) system for C++
- ORMLite: Lightweight object–relational mapping (ORM) framework in Java for JDBC and Android[3]
- Microsoft Entity Framework
- DBIx::Class object–relational mapping (ORM) module for Perl
- TuxORM: Simple object–relational mapping (ORM) library in Java for JDBC
- Persist (Java tool) Java-based object–relational mapping and data access object tool
See also
References
- "Core J2EE Patterns - Data Access Objects". Sun Microsystems Inc. 2007-08-02.
- See http://www.ibm.com/developerworks/java/library/j-genericdao/index.html for workarounds
- Hodgson, Kyle; Reid, Darren (2015-01-23). ServiceStack 4 Cookbook. Packt Publishing Ltd. p. Chapter 4. ISBN 9781783986576. Retrieved 22 June 2016.
|url=https://www.oracle.com/java/technologies/data-access-object.html