Java Mailing List Archive

http://www.junlu.com/

Google
Google
Mailing List
Home
Forum Home
JBoss - Java Application Server
Tomcat - JSP/Servlet container
Struts - A MVC web framework
iText - An open source PDF Java Library
JDOM - JDOM XML Parser
JSP - A mailing list about Java Server Pages specification and reference
J2EE - A mailing list for Java(tm) 2 Platform, Enterprise Edition
J2EE Pattern - An interest list for Sun Java Center J2EE Pattern Catalog
Servlet - A mailing list for discussion about Sun Microsystem's Java Servlet API Technology
Struts & Hibernate
Subjects
JSP editor plugin for eclipse ?
org apache jasper JasperException: Unable to compile class for JSP
Tomcat: Connection reset by peer: socket write error
Cannot retrieve definition for form bean null
Struts Tiles Tutorial (free Struts training)
Where do I download Tomcat 4 0 6?
Data Access Object (DAO) pattern, example DAO 's
Where to download Tomcat v 4 1 24 from?
Tomcat 5 0 16 Requested resource not available
Subject: Servlet : Session invalidate
Oracle Connection Pooling in 3 2 2
Servlet action is currently unavailable
Tomcat/Struts Unicode Encoding/Decoding problems
Subject: Running a Simple JMS Example
Tomcat and webapplication specific java library path
Mapping in workers2 properties
org apache jasper JasperException
problem with html:text bean throwing exception
Cannot find message resources under key org apache struts action
   MESSAGE
Cannot find message resources under key org apache struts action MESSAGE
invalid direct reference problem with solution
Tool for jsp debug Try Sysdeo Eclipse Plugin
Tomcat 5 Cannot load JDBC driver class 'null ' SQL state: null
weblogic ejbc
java properties file
Jboss 3 2 3 Coyote Can 't re
Tomcat 5, Apache2 and mod jk2 integration problem
JBoss example problem new to J2EE
Value attribute of <html:checkbox
url string for connecting jboss to oracle
javax servlet ServletException: BeanUtils populate
5 0 18: Windows XP Pro vs Windows 2000
HTTP Status 404 The requested resource is not available
 
DAO pattern

DAO pattern

2004-11-21       - By Ananthalakshmi Subramaniyam

 Back
Reply:     1     2     3     4     5     6     7     8     9     10     >>  

On Thu, 18 Nov 2004 23:11:06 -0700, Darshan Kashi <dkumar@(protected)>
wrote:

>Hi,
>
> Thanks for your reply. I just gone through the link you provided, and its
>really useful for me. There is one point i need some clarification.
>
>In that article the author mentioned two approaches
>
>1. Transaction demarcation using JDBC
>       (The <B>caller has no way to demarcate</B> the transaction)
>2. Transaction demarcation using JTA
>        (The <B>caller is responsible for demarcating</B> the transaction)
>
>I need to control the trasaction from the caller(not in DAO), and at the
>same time i don't want to go for JTA. Is it not possible?
>
>Regards
>Darshan
>
>
>On Thu, 18 Nov 2004 09:24:35 -0300, German M. Gomez
><german_m_gomez@(protected)> wrote:
>
>>I believe you will find this link useful http://www-
>106.ibm.com/developerworks/java/library/j-dao/
>>
>>See Transaction demarcation
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>__ ____ ____ ____ ____ ____ ____ __
>>?Llevate a Yahoo! en tu Unif??? >>Ahora pod?? usar Yahoo! Messenger en tu
Unif??? en cualquier momento y
>lugar.
>>Encontr? ??? informaci?? ?n: http://ar.mobile.yahoo.com/sms.html
>>
>>===================================================================>
>Companion Site: http://www.corej2eepatterns.com
>>J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
>>List Archive: http://archives.java.sun.com/archives/j2eepatterns-
>interest.html
>>Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to
>listserv@(protected)
>
>===================================================================>Companion
Site: http://www.corej2eepatterns.com
>J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
>List Archive: http://archives.java.sun.com/archives/j2eepatterns-
interest.html
>Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to
listserv@(protected)

Hi,

Normally, it is best practice to handle Transaction demarcation outside of
DAO, in order to demarcate Transaction between multiple DAOs. This approach
is more flexible.

For example,

public class UserTransaction {
  Connection conn = null;
  String strUser = null;
  String strDbUrl = null;
  String strDbUser = null;
  String strPassword = null;

  public UserTransaction(String strURL, String strUser,
                         String strPassword) {
   this.strDbUrl = strURL;
   this.strDbUser = strUser;
   this.strPassword = strPassword;
  }
  public void beginTransaction(...) {}
  public void endTransaction(...) {}
  public Connection getConnection() {return connection;}
  public void commit() {}
  public void rollback() {}
}
public class MyDAOFactory {
  public static UserTransaction transaction = null;
  public static final String DRIVER    "COM.cloudscape.core.RmiJdbcDriver";
  public static final String DBURL    "jdbc:cloudscape:rmi://localhost:1099
/CoreJ2EEDB";
  public static final String USER ="user";
  public static final String PASSWORD = "pwd";

  public static UserTransaction getUserTransaction() {
    if(transaction == null ) {
      UserTransaction transaction = new UserTransaction
(DRIVER,DBRUL,USER,PASSWORD);
    }
    return transaction;
  }
  ...
  public AccountDAO getAccountDAO();
}
public class AccountDAO {
  public void credit() {
   UserTransaction transaction        MyDAOFactory.getUserTransaction();/use
existing user transaction or
                                         create new one.
   Connection connection = transaction.getConnection();
   Statement stmt = connection.createStatement(sqlQuery);
   //do the operations.
  }
  public void debit() {}
  ...
}

In Caller class,

MyDAOFactory daoFactory = new MyDAOFactory();
UserTransaction transaction = MyDAOFactory.getUserTransaction();
transaction.beginTransaction();
AccountDAO accountDAO = daoFactory.getAccountDAO();
try {
accountDAO.credit();
accountDAO.debit();
...
transaction.commit();
} catch(myDAOException ex) {
 transaction.rollback();
}
transaction.endTransaction();

The above approach is helpful in both DAO demarcated Transaction and
caller demarcated transaction. ie, in DAO demarcated methods, you may have
the following implementation,

public void autonomousCredit() {
   UserTransaction transaction        MyDAOFactory.getUserTransaction();/use
existing user transaction or
                                         create new one.
   transaction.beginTransaction();
   Connection connection = transaction.getConnection();
   Statement stmt = connection.createStatement(sqlQuery);
   try {
     //do the operations.
     transaction.commit();
   } catch(Exception ex) {
     transaction.rollback();
   }
   transaction.endTransaction();
}

Thanks,
H.Ananthalakshmi.Hi,

Normally, it is best practice to handle Transaction demarcation outside of
DAO, in order to demarcate Transaction between multiple DAOs. This approach
is more flexible.

For example,

public class UserTransaction {
  Connection conn = null;
  String strUser = null;
  String strDbUrl = null;
  String strDbUser = null;
  String strPassword = null;

  public UserTransaction(String strURL, String strUser,
                         String strPassword) {
   this.strDbUrl = strURL;
   this.strDbUser = strUser;
   this.strPassword = strPassword;
  }
  public void beginTransaction(...) {}
  public void endTransaction(...) {}
  public Connection getConnection() {return connection;}
  public void commit() {}
  public void rollback() {}
}
public class MyDAOFactory {
  public static UserTransaction transaction = null;
  public static final String DRIVER    "COM.cloudscape.core.RmiJdbcDriver";
  public static final String DBURL    "jdbc:cloudscape:rmi://localhost:1099
/CoreJ2EEDB";
  public static final String USER ="user";
  public static final String PASSWORD = "pwd";

  public static UserTransaction getUserTransaction() {
    if(transaction == null ) {
      UserTransaction transaction = new UserTransaction
(DRIVER,DBRUL,USER,PASSWORD);
    }
    return transaction;
  }
  ...
  public AccountDAO getAccountDAO();
}
public class AccountDAO {
  public void credit() {
   UserTransaction transaction        MyDAOFactory.getUserTransaction();/use
existing user transaction or
                                         create new one.
   Connection connection = transaction.getConnection();
   Statement stmt = connection.createStatement(sqlQuery);
   //do the operations.
  }
  public void debit() {}
  ...
}

In Caller class,

MyDAOFactory daoFactory = new MyDAOFactory();
UserTransaction transaction = MyDAOFactory.getUserTransaction();
transaction.beginTransaction();
AccountDAO accountDAO = daoFactory.getAccountDAO();
try {
accountDAO.credit();
accountDAO.debit();
...
transaction.commit();
} catch(myDAOException ex) {
 transaction.rollback();
}
transaction.endTransaction();

The above approach is helpful in both DAO demarcated Transaction and
caller demarcated transaction. ie, in DAO demarcated methods, you may have
the following implementation,

public void autonomousCredit() {
   UserTransaction transaction        MyDAOFactory.getUserTransaction();/use
existing user transaction or
                                         create new one.
   transaction.beginTransaction();
   Connection connection = transaction.getConnection();
   Statement stmt = connection.createStatement(sqlQuery);
   try {
     //do the operations.
     transaction.commit();
   } catch(Exception ex) {
     transaction.rollback();
   }
   transaction.endTransaction();
}

Thanks,
H.Ananthalakshmi.

===================================================================Companion
Site: http://www.corej2eepatterns.com
J2EE BluePrints: http://java.sun.com/blueprints/corej2eepatterns
List Archive: http://archives.java.sun.com/archives/j2eepatterns-interest.html
Unsubscribing: email "signoff J2EEPATTERNS-INTEREST" to listserv@(protected)

©2008 junlu.com - Jax Systems, LLC, U.S.A.