Main Page | Packages | Class Hierarchy | Alphabetical List | Class List | File List | Class Members | Related Pages

ExecWriteRequest.java

00001 /**
00002  * C-JDBC: Clustered JDBC.
00003  * Copyright (C) 2002-2005 French National Institute For Research In Computer
00004  * Science And Control (INRIA).
00005  * Contact: c-jdbc@objectweb.org
00006  * 
00007  * This library is free software; you can redistribute it and/or modify it
00008  * under the terms of the GNU Lesser General Public License as published by the
00009  * Free Software Foundation; either version 2.1 of the License, or any later
00010  * version.
00011  * 
00012  * This library is distributed in the hope that it will be useful, but WITHOUT
00013  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00014  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
00015  * for more details.
00016  * 
00017  * You should have received a copy of the GNU Lesser General Public License
00018  * along with this library; if not, write to the Free Software Foundation,
00019  * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
00020  *
00021  * Initial developer(s): Emmanuel Cecchet.
00022  * Contributor(s): ______________________.
00023  */
00024 
00025 package org.objectweb.cjdbc.controller.virtualdatabase.protocol;
00026 
00027 import java.sql.SQLException;
00028 
00029 import org.objectweb.cjdbc.common.i18n.Translate;
00030 import org.objectweb.cjdbc.common.sql.AbstractWriteRequest;
00031 import org.objectweb.cjdbc.controller.loadbalancer.AllBackendsFailedException;
00032 import org.objectweb.cjdbc.controller.requestmanager.distributed.DistributedRequestManager;
00033 
00034 /**
00035  * Execute a write request between several controllers.
00036  * 
00037  * @author <a href="mailto:Emmanuel.Cecchet@inria.fr">Emmanuel Cecchet </a>
00038  * @version 1.0
00039  */
00040 public class ExecWriteRequest extends DistributedRequest
00041 {
00042   /**
00043    * @param request write request to execute
00044    */
00045   public ExecWriteRequest(AbstractWriteRequest request)
00046   {
00047     super(request);
00048   }
00049 
00050   /**
00051    * @see org.objectweb.cjdbc.controller.virtualdatabase.protocol.DistributedRequest#scheduleRequest(org.objectweb.cjdbc.controller.requestmanager.distributed.DistributedRequestManager)
00052    */
00053   public void scheduleRequest(DistributedRequestManager drm)
00054       throws SQLException
00055   {
00056     drm.scheduleExecWriteRequest((AbstractWriteRequest) request);
00057   }
00058 
00059   /**
00060    * @see org.objectweb.cjdbc.controller.virtualdatabase.protocol.DistributedRequest#executeScheduledRequest(org.objectweb.cjdbc.controller.requestmanager.distributed.DistributedRequestManager)
00061    */
00062   public Object executeScheduledRequest(DistributedRequestManager drm)
00063       throws SQLException
00064   {
00065     try
00066     {
00067       int execWriteRequestResult = 0;
00068       try
00069       {
00070         execWriteRequestResult = drm
00071             .loadBalanceExecWriteRequest((AbstractWriteRequest) request);
00072       }
00073       catch (AllBackendsFailedException e)
00074       {
00075         drm.updateAndNotifyExecWriteRequest((AbstractWriteRequest) request,
00076             false);
00077         drm.addFailedOnAllBackends(request);
00078         if (drm.getLogger().isDebugEnabled())
00079           drm
00080               .getLogger()
00081               .debug(
00082                   Translate
00083                       .get(
00084                           "virtualdatabase.distributed.write.all.backends.locally.failed",
00085                           request.getSQLShortForm(drm.getVirtualDatabase()
00086                               .getSQLShortFormLength())));
00087         return e;
00088       }
00089       drm.updateAndNotifyExecWriteRequest((AbstractWriteRequest) request, true);
00090       return new Integer(execWriteRequestResult);
00091     }
00092     catch (SQLException e)
00093     {
00094       drm.getLogger().warn(
00095           Translate.get("virtualdatabase.distributed.write.sqlexception", e
00096               .getMessage()), e);
00097       throw e;
00098     }
00099     catch (RuntimeException re)
00100     {
00101       drm.getLogger().warn(
00102           Translate.get("virtualdatabase.distributed.write.exception", re
00103               .getMessage()), re);
00104       throw new SQLException(re.getMessage());
00105     }
00106   }
00107 
00108 }

Generated on Mon Apr 11 22:01:32 2005 for C-JDBC by  doxygen 1.3.9.1