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

ExecWriteRequestWithKeys.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.sql.AbstractWriteRequest;
00030 import org.objectweb.cjdbc.controller.loadbalancer.AllBackendsFailedException;
00031 import org.objectweb.cjdbc.controller.requestmanager.distributed.DistributedRequestManager;
00032 import org.objectweb.cjdbc.controller.virtualdatabase.ControllerResultSet;
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 ExecWriteRequestWithKeys extends DistributedRequest
00041 {
00042   /**
00043    * @param request write request to execute
00044    */
00045   public ExecWriteRequestWithKeys(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       ControllerResultSet execWriteRequestResult = null;
00068       try
00069       {
00070         execWriteRequestResult = drm
00071             .loadBalanceExecWriteRequestWithKeys((AbstractWriteRequest) request);
00072       }
00073       catch (AllBackendsFailedException e)
00074       {
00075         drm.updateAndNotifyExecWriteRequest((AbstractWriteRequest) request,
00076             false);
00077         drm.addFailedOnAllBackends(request);
00078       }
00079       drm.updateAndNotifyExecWriteRequest((AbstractWriteRequest) request, true);
00080       return execWriteRequestResult;
00081     }
00082     catch (SQLException e)
00083     {
00084       return e;
00085     }
00086   }
00087 
00088 }

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