Tutorials : Using DAOs in Apache Struts :

Using DAOs in Apache Struts

by Keld H. Hansen

Introduction

One of the most popular design patterns is the Data Access Object (DAO) pattern. It's used when you want to separate your presentation code from the code that accesses the back-end containing your data. The back-end is typically a database, but it could be anything: a flat file on your hard disk, a message queue connecting to a mainframe, or a web service interface to some server.

It you're working with an application managing customers, then a DAO module would typically offer functions for "create customer", "update customer", "delete customer", etc.

When the client uses the DAO pattern it does not know how the back-end is implemented. This makes it possible to replace a back-end using a database with for example a web service, without changing one line of code in the client. This is probably not something you do very often, but when you're developing and testing an application, the DAO pattern makes it possible to replace the back-end with something that is simpler to test against--for example a simulated database. Of course this only tests the front-end logic. The back-end logic will also have to be tested.

Another benefit of using the DAO pattern is that you can use the DAO modules for many types of clients: web browsers, Swing clients, web services, and background tasks.

In this article we'll start with a very simple application, and build several DAOs using various types of back-end implementations. 

The Case

We need a case that is simple, so we can keep the focus on the DAO technique, but at the same time it shouldn't be so simple so that it neglects to demonstrate how DAOs are used in real life projects. I've used the DVD library example in many of my other articles, so why not once more? Since the example is simple, I'll include code for complete logging and error handling.

We'd like to create an application built on DAOs that can manage a collection of DVDs. A DVD is represented as simply as possible by a unique "id" and a title:

id A string that uniquely identifies the DVD.
This id can be used as the key in a database table. 
title A string that contains the title of the DVD, typically the title of a movie.
This title represents the "data part" of a database record. 

One DVD can be implemented in Java as a bean:

package dk.hansen;

public class DVD {

  private String id;
  private String title;

  public DVD(String id, String title) {
    setId(id);
    setTitle(title);
  }

  public String getId() {return id;}

  public void setId(String id) {this.id = id;}

  public String getTitle() {return title;}

  public void setTitle(String title) {this.title = title;}

}

The DVD class can, without problem, be mapped to a database table with two columns.

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.