Class OracleXAResource

java.lang.Object
oracle.jdbc.xa.OracleXAResource
All Implemented Interfaces:
XAResource, oracle.jdbc.diagnostics.Diagnosable, oracle.jdbc.diagnostics.PropertyChangeListener, oracle.jdbc.internal.Monitor
Direct Known Subclasses:
OracleXAResource

public abstract class OracleXAResource extends Object implements XAResource, oracle.jdbc.internal.Monitor, oracle.jdbc.diagnostics.Diagnosable
An Oracle XA Resource.
  • Field Details

  • Constructor Details

    • OracleXAResource

      public OracleXAResource()
    • OracleXAResource

      public OracleXAResource(Connection pm_conn, OracleXAConnection xaconn) throws XAException
      OracleXAResource() -- The initializer.
      Throws:
      XAException - throws an exception if the connection object is null.
  • Method Details

    • getPhysicalConnection

      protected final oracle.jdbc.internal.OracleConnection getPhysicalConnection() throws XAException
      Returns the physical connection that this OracleXAResource object should use. If the physical connection is proxied by a replayable connection, the replay function will be disabled.
      Throws:
      XAException
    • removeXidFromList

      protected final boolean removeXidFromList(Xid xid)
    • isOnStack

      protected final boolean isOnStack(Xid xid) throws XAException
      Throws:
      XAException
    • isXidListEmpty

      protected final boolean isXidListEmpty()
    • createOrUpdateXid

      protected void createOrUpdateXid(Xid xid, boolean isSuspended, boolean[] isLocallySuspended)
      createOrUpdateXid () - Pushes the current xid. This should be called from start.
      Parameters:
      xid - Xid to save.
    • updateXidList

      protected boolean updateXidList(Xid xid, boolean[] flags)
      updateXidList() - Update the Xid status in the list
      Returns:
      true - if the xid is found the xidlist false - if the xid is not found the xidlist
    • isXidSuspended

      protected boolean isXidSuspended(Xid xid) throws XAException
      isXidSuspended(Xid) - Checks if the passed Xid is suspended or not.
      Throws:
      XAException - if the suspend operation fails.
    • suspendStacked

      protected Xid suspendStacked(Xid xid) throws XAException
      suspendStacked() - Suspends the stacked transaction, if any. This version should be called at the beginning of commit, rollback, and prepare.
      Parameters:
      xid - Xid of current transaction. If this is different from the stacked Xid, the stacked Xid will be suspended, clearing the way for the current operation.
      Returns:
      null if there was no stacked Xid, otherwise the Xid which was stacked.
      Throws:
      XAException - if the suspend operation fails.
    • resumeStacked

      protected void resumeStacked(Xid xid) throws XAException
      resumeStacked() - Resumes the current transaction after the possible suspension of the stacked transaction, if any. This should be called from the end of commit, rollback, prepare, and end.
      Parameters:
      xid - Xid of stacked transaction. If null, then this is a no-op.
      Throws:
      XAException - if the resume operation fails.
    • start

      public abstract void start(Xid xid, int flag) throws XAException
      start() -- Starts work on behalf of a transaction branch. If TMJOIN is specified, the start is for joining an existing txn branch xid. If TMRESUME is specified, the start is to resume a suspended transaction branch specified in xid. Transaction suspend is done by calling the end method specifying the TMSUSPEND flag. If neither TMJOIN nor TMRESUME is specified and the transaction branch specified in xid already exists, the resource manager raises the duplicate transaction exception via XAER_DUPID.
      Specified by:
      start in interface XAResource
      Parameters:
      xid - A global transaction identifier.
      Throws:
      XAException - An error has occurred. Possible exceptions are XA_RB, XAER_RMERR, XAER_RMFAIL, XAER_DUPID, XAER_OUTSIDE, XAER_NOTA, XAER_INVAL, or XAER_PROTO.
    • end

      public abstract void end(Xid xid, int flag) throws XAException
      end()-- End work performed on behalf of a transaction branch. The resource manager dissociates the XA resource from the transaction branch specified and let the transaction be completed. If TMSUSPEND is specified in flag, the txn branch is temporarily suspended in incomplete state. The txn context is in suspended state and must be resumed via start with TMRESUME specified. If TMFAIL is specified, the portion of work has failed. The RM may mark the transaction as rollback-only. If TMSUCCESS is specified, the portion of work has completed successfully.
      Specified by:
      end in interface XAResource
      Parameters:
      xid - A global transaction identifier that is the same as what was used previously in the start method.
      flag - One of TMSUCCESS, TMFAIL, or TMSUSPEND.
      Throws:
      XAException - An error has occurred. Possible XAException values are XAER_RMERR, XAER_RMFAILED, XAER_NOTA, XAER_INVAL, XAER_PROTO, or XA_RB.
    • commit

      public abstract void commit(Xid xid, boolean onePhase) throws XAException
      commit() -- Commit work done by global transaction specified by xid.
      Specified by:
      commit in interface XAResource
      Parameters:
      xid - A global transaction identifier.
      onePhase - If true, the RM should use a 1-phase commit protocol to commit the work done on behalf of xid.
      Throws:
      XAException - (An error has occurred.) Possible XAExceptions are XA_HEURHAZ, XA_HEURCOM, XA_HEURRB, XA_HEURMIX, XAER_RMERR, XAER_RMFAIL, XAER_NOTA, XAER_INVAL, or XAER_PROTO. If the resource manager did not commit the txn and the parameter onePhase is set to true, the RM may raise one of the XA_RB exceptions. Upon return, the RM has rolled back the branch's work and has released all held resources.
    • prepare

      public abstract int prepare(Xid xid) throws XAException
      prepare() -- Ask RM to prepare for a commit of the txn specified in xid.
      Specified by:
      prepare in interface XAResource
      Parameters:
      xid - A global transaction identifier.
      Returns:
      A value indicating the resource manager's vote on the outcome of the txn. The possible values are: XA_RDONLY or XA_OK. If the RM wants to roll back the transaction, it should do so by raising an appropriate XAException in the prepare method.
      Throws:
      XAException - (An error has occurred.) Possible exception values are: XA_RB, XAER_RMERR, XAER_RMFAIL, XAER_NOTA, XAER_INVAL, or XAER_PROTO.
    • forget

      public abstract void forget(Xid xid) throws XAException
      forget() -- Tell RM to forget about a heuristically completed txn branch
      Specified by:
      forget in interface XAResource
      Parameters:
      xid - A global transaction identifier.
      Throws:
      XAException - An error has occurred. Possible exception values are XAER_RMERR, XAER_RMFAIL, XAER_NOTA, XAER_INVAL, or XAER_PROTO.
    • rollback

      public abstract void rollback(Xid xid) throws XAException
      rollback() -- Ask RM to roll back work done on behalf of a txn branch.
      Specified by:
      rollback in interface XAResource
      Parameters:
      xid - A global transaction identifier.
      Throws:
      XAException - An error has occurred.
    • recover

      public Xid[] recover(int flag) throws XAException
      Obtain a list of prepared transaction branches from a resource manager. The transaction manager calls this method during recovery to obtain the list of transaction branches that are currently in prepared or heuristically completed states. JDBC has been returning a complete list of prepared transaction branches when recover(flag) is called regardless which flag (TMNOFLAGS or TMSTARTRSCAN or TMENDRSCAN) is set. Beginning in 11.2.0.2, JDBC will do the following in order to accommodate certain TMs way of handling the recovery scan:
      • If recover(TMSTARTRSCAN) is called, continues to return a complete list of prepared transaction branches.
      • If recover(TMNOFLAGS) is called after a TMSTARTSCAN, returns an empty list until the scan is ended. Otherwise, continues to return a complete list of prepared transaction branches.
      • If recover(TMENDRSCAN) is called after a TMSTARTSCAN, ends the scan and returns an empty list. Otherwise, continues to return a complete list of prepared transaction branches until TMSTARTRSCAN is called again.

      Example 1:

            MyXid[] xids = 
               xaRes.recover(XAResource.TMSTARTRSCAN | XAResource.TMENDRSCAN);
            for (int i=0; xids != null && i < xids.length; i++) {
            try {
               xaRes.rollback(xids[i]);
            ...
           

      Example 2:

            MyXid[] xids = xaRes.recover(XAResource.TMSTARTRSCAN);
            while( xids!=null && xids.length>0)
            {
               for (int i=0; i < xids.length; i++) {
               try {
                  xaRes.rollback(xids[i]);
                  ...
                  xids = xaRes.recover(XAResource.TMNOFLAG);
            }
            xaRes.recover(XAResource.TMENDRSCAN);
           

      Example 3:

            MyXid[] xids = xaRes.recover(XAResource.TMNOFLAG);
            for (int i=0; xids != null && i < xids.length; i++) {
            try {
               xaRes.rollback(xids[i]);
            ...
            
      Specified by:
      recover in interface XAResource
      Parameters:
      flag - One of TMSTARTRSCAN, TMENDRSCAN, TMNOFLAGS. TMNOFLAGS must be used when no other flags are set in flags.
      Returns:
      The resource manager returns zero or more XIDs for the transaction branches that are currently in a prepared or heuristically completed state. If an error occurs during the operation, the resource manager should raise the appropriate XAException.
      Throws:
      XAException - An error has occurred. Possible values are XAER_RMERR, XAER_RMFAIL, XAER_INVAL, and XAER_PROTO.
    • restoreAutoCommitModeForSessionlessTransaction

      protected void restoreAutoCommitModeForSessionlessTransaction() throws XAException
      Restore the auto-commit status of the Connection and the PooledConnection Typically, invoked after ending a sessionless transaction.
      Throws:
      XAException
    • restoreAutoCommitModeForGlobalTransaction

      protected void restoreAutoCommitModeForGlobalTransaction() throws XAException
      Restore the auto-commit status of the Connection & the PooledConnection. Typically, invoked after the end of a global transaction.
      Throws:
      XAException
    • saveAndAlterAutoCommitModeForSessionlessTransaction

      protected void saveAndAlterAutoCommitModeForSessionlessTransaction() throws XAException
      Save the auto-commit status of the Connection and the PooledConnection Typically, invoked before starting a sessionless transaction.
      Throws:
      XAException
    • saveAndAlterAutoCommitModeForGlobalTransaction

      protected void saveAndAlterAutoCommitModeForGlobalTransaction() throws XAException
      Save the auto-commit status of the Connection & the PooledConnection. Typically, invoked just before starting the transaction.
      Throws:
      SQLException
      XAException
    • getTransactionTimeout

      public int getTransactionTimeout() throws XAException
      Obtain the current transaction timeout value set for this XAResource instance. If XAResource.setTransactionTimeout was not use prior to invoking this method, the return value is the default timeout set fo the resource manager; otherwise, the value used in the previous setTransactionTimeout call is returned.

      Specified by:
      getTransactionTimeout in interface XAResource
      Returns:
      the transaction timeout value in seconds.
      Throws:
      XAException - - An error has occurred. Possible exception values are XAER_RMERR, XAER_RMFAIL.
    • isSameRM

      public boolean isSameRM(XAResource xares) throws XAException
      This method is called to determine if the resource manager instance represented by the target object is the same as the resource manager instance represented by the parameter xares.
      Specified by:
      isSameRM in interface XAResource
      Parameters:
      xares - - An XAResource object whose resource manager instance is to be compared with the resource manager instance of the target object.
      Returns:
      true if it's the same RM instance; otherwise false.
      Throws:
      XAException - - An error has occurred. Possible exception values are XAER_RMERR, XAER_RMFAIL.
    • setTransactionTimeout

      public boolean setTransactionTimeout(int seconds) throws XAException
      Set the current transaction timeout value for this XAResource instance. Once set, this timeout value is effective until setTransactionTimeout is invoked again with a different value. To reset the timeout value to the default value used by the resource manager, set the value to zero. If the timeout operation is performed successfully, the method returns true; otherwise false. If a resource manager does not support transaction timeout value to be set explicitly, this method returns false.

      Specified by:
      setTransactionTimeout in interface XAResource
      Parameters:
      seconds - - transaction timeout value in seconds.
      Returns:
      true if transaction timeout value is set successfully; otherwise false.
      Throws:
      XAException - - An error has occurred. Possible exception values are XAER_RMERR, XAER_RMFAIL, or XAER_INVAL.
    • allowGlobalTxnModeOnly

      protected void allowGlobalTxnModeOnly(int errorCode) throws XAException
      Throws:
      XAException
    • exitGlobalTxnMode

      protected void exitGlobalTxnMode()
    • enterGlobalTxnMode

      protected void enterGlobalTxnMode()
    • checkError

      protected void checkError(int error) throws XAException
      Throws:
      XAException
    • checkError

      protected void checkError(int error, SQLException sqlException) throws XAException
      Throws:
      XAException
    • checkError

      protected void checkError(int error, int defaultXAError) throws XAException
      Throws:
      XAException
    • convertError

      protected XAException convertError(SQLException sqlex, int defaultXAError)
      Convert a SQLException into an XAException.
      Returns:
      An XAException with the SQLException as it's cause.
    • getConnectionDuringExceptionHandling

      protected oracle.jdbc.internal.OracleConnection getConnectionDuringExceptionHandling()
    • getMonitorLock

      public final oracle.jdbc.internal.Monitor.CloseableLock getMonitorLock()
      Specified by:
      getMonitorLock in interface oracle.jdbc.internal.Monitor
    • getDiagnosable

      public oracle.jdbc.diagnostics.Diagnosable getDiagnosable()
      Specified by:
      getDiagnosable in interface oracle.jdbc.diagnostics.Diagnosable