DAO stands for Data Access Object. DAO Design Pattern is used to separate the data persistence logic in a separate layer. This way, the service remains completely in dark about how the low-level operations to access the database is done. This is known as the principle of Separation of Logic.
With DAO design pattern, we have following components on which our design depends:
With above mentioned components, let’s try to implement the DAO pattern. We will use 3 components here:
Book
model which is transferred from one layer to the other.BookDao
interface that provides a flexible design and API to implement.BookDaoImpl
concrete class that is an implementation of the BookDao
interface.Let us put this logic into a diagram:
Now, let’s put up our model object.
package com.journaldev.model;
public class Books {
private int isbn;
private String bookName;
public Books() {
}
public Books(int isbn, String bookName) {
this.isbn = isbn;
this.bookName = bookName;
}
// getter setter methods
}
It is a simple object with just 2 properties to keep things simple.
Let’s define the interface to access the data associated with it at persistence level.
package com.journaldev.dao;
import com.journaldev.model.Books;
import java.util.List;
public interface BookDao {
List<Books> getAllBooks();
Books getBookByIsbn(int isbn);
void saveBook(Books book);
void deleteBook(Books book);
}
Next, we create a concrete class implementing the above interface.
package com.journaldev.daoimpl;
import com.journaldev.dao.BookDao;
import com.journaldev.model.Books;
import java.util.ArrayList;
import java.util.List;
public class BookDaoImpl implements BookDao {
//list is working as a database
private List<Books> books;
public BookDaoImpl() {
books = new ArrayList<>();
books.add(new Books(1, "Java"));
books.add(new Books(2, "Python"));
books.add(new Books(3, "Android"));
}
@Override
public List<Books> getAllBooks() {
return books;
}
@Override
public Books getBookByIsbn(int isbn) {
return books.get(isbn);
}
@Override
public void saveBook(Books book) {
books.add(book);
}
@Override
public void deleteBook(Books book) {
books.remove(book);
}
}
Finally, we put this implementation to use in our main() method:
package com.journaldev;
import com.journaldev.dao.BookDao;
import com.journaldev.daoimpl.BookDaoImpl;
import com.journaldev.model.Books;
public class AccessBook {
public static void main(String[] args) {
BookDao bookDao = new BookDaoImpl();
for (Books book : bookDao.getAllBooks()) {
System.out.println("Book ISBN : " + book.getIsbn());
}
//update student
Books book = bookDao.getAllBooks().get(1);
book.setBookName("Algorithms");
bookDao.saveBook(book);
}
}
There are many advantages for using DAO pattern. Let’s state some of them here:
In this article, we learned how we can put DAO design pattern to use to emphasize on keeping persistence logic separate and so, our components loosely coupled. Design patterns are just based on a way of programming and so, is language and framework independent. Feel free to leave your views in comments below. Download the DAO example project from below link.
Download DAO Pattern Example Project
References: Oracle Documentation, Wikipedia.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
While we believe that this content benefits our community, we have not yet thoroughly reviewed it. If you have any suggestions for improvements, please let us know by clicking the “report an issue“ button at the bottom of the tutorial.
Thanks a lot for the explanation
- C S Chakravarthi
thanks
- arun singh
DAO Design Pattern belongs to which design pattern - Structural or Behavioural DP?
- Hemanth Kumar
Please correct me if I’m wrong but I’m wondering if there’s a typo in “While changing a persistence mechanism, service layer doesn’t even have to know where the data comes from. For example, if you’re thinking of shifting from using MySQL to MongoDB, all changes are needed to be done in the DAO layer only.” I think the changes are needed to be done in the Impl layer instead. Looking forward to your reply.
- Jane
Good Explanation on Design patterns and it would be more easy to understand if shown using diagram
- Sameer
Thank you for the explanation :-)
- Medy
The class name should be Book, not Books…
- Rujhan Arora
Thanks for the great explanation I’ve been searching this kind of stuff. But what if we want to integrate this with mysql as in the above code you use list as database so how we can create a dao through which we can perform CRUD operation in sql . Thanks for your efforts ,
- cs…
so primary and the code style is not good.
- yzwall
Never give up is the only secret to your dreams
- Franklin.Ingrid