Class AbstractJDBCDatabaseInterface

  • All Implemented Interfaces:
    DatabaseInterface
    Direct Known Subclasses:
    JDBCDatabaseInterface

    public abstract class AbstractJDBCDatabaseInterface
    extends java.lang.Object
    implements DatabaseInterface
    An abstract implementation of JDBCDatabaseInterface that provides a connection between a single DatabaseConnection and a DatabaseInterface implementation.

    This receives database commands from the JDBC layer and dispatches the queries to the database system. It also manages ResultSet maps for query results.

    This implementation does not handle authentication (login) / construction of the DatabaseConnection object, or disposing of the connection.

    This implementation ignores the AUTO-COMMIT flag when a query is executed. To implement AUTO-COMMIT, you should 'commit' after a command is executed.

    SYNCHRONIZATION: This interface is NOT thread-safe. To make a thread-safe implementation use the LockingMechanism.

    See JDBCDatabaseInterface for a standard server-side implementation of this class.

    Author:
    Tobias Downer
    • Method Summary

      All Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      protected void checkNotDisposed()
      Checks if the interface is disposed, and if it is generates a friendly SQLException informing the user of this.
      protected void clearResultSetMap()
      Clears the contents of the result set map.
      DebugLogger Debug()
      Returns a DebugLogger object that can be used to log debug messages against.
      void disposeResult​(int result_id)
      Disposes of a result of a query on the server.
      void disposeStreamableObject​(int result_id, long streamable_object_id)
      Disposes a streamable object channel with the given identifier.
      QueryResponse execQuery​(SQLQuery query)
      Executes the query and returns a QueryResponse object that describes the result of the query.
      void finalize()
      Clean up if this object is GC'd.
      protected Database getDatabase()
      Returns the Database that is the context of this interface.
      protected DatabaseConnection getDatabaseConnection()
      Returns the DatabaseConnection objcet for this connection.
      ResultPart getResultPart​(int result_id, int row_number, int row_count)
      Returns a part of a result set.
      StreamableObjectPart getStreamableObjectPart​(int result_id, long streamable_object_id, long offset, int len)
      Returns a section of a large binary or character stream in a result set.
      protected User getUser()
      Returns the User object for this connection.
      protected java.sql.SQLException handleExecuteThrowable​(java.lang.Throwable e, SQLQuery query)
      Wraps a Throwable thrown by the execution of a query in DatabaseConnection with an SQLException and puts the appropriate error messages to the debug log.
      protected void init​(User user, DatabaseConnection connection)
      Initializes this database interface with a User and DatabaseConnection object.
      protected void internalDispose()
      Disposes all resources associated with this object.
      void pushStreamableObjectPart​(byte type, long object_id, long object_length, byte[] buf, long offset, int length)
      Pushes a part of a streamable object from the client onto the server.
      • Methods inherited from class java.lang.Object

        clone, equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Constructor Detail

      • AbstractJDBCDatabaseInterface

        public AbstractJDBCDatabaseInterface​(Database database)
        Sets up the database interface.
    • Method Detail

      • init

        protected final void init​(User user,
                                  DatabaseConnection connection)
        Initializes this database interface with a User and DatabaseConnection object. This would typically be called from inside an authentication method, or from 'login'. This must be set before the object can be used.
      • getDatabase

        protected final Database getDatabase()
        Returns the Database that is the context of this interface.
      • getUser

        protected final User getUser()
        Returns the User object for this connection.
      • Debug

        public final DebugLogger Debug()
        Returns a DebugLogger object that can be used to log debug messages against.
      • getDatabaseConnection

        protected final DatabaseConnection getDatabaseConnection()
        Returns the DatabaseConnection objcet for this connection.
      • clearResultSetMap

        protected final void clearResultSetMap()
        Clears the contents of the result set map. This removes all result_id ResultSetInfo maps.
      • handleExecuteThrowable

        protected final java.sql.SQLException handleExecuteThrowable​(java.lang.Throwable e,
                                                                     SQLQuery query)
        Wraps a Throwable thrown by the execution of a query in DatabaseConnection with an SQLException and puts the appropriate error messages to the debug log.
      • internalDispose

        protected final void internalDispose()
        Disposes all resources associated with this object. This clears the ResultSet map, and NULLs all references to help the garbage collector. This method would normally be called from implementations of the 'dispose' method.
      • checkNotDisposed

        protected final void checkNotDisposed()
                                       throws java.sql.SQLException
        Checks if the interface is disposed, and if it is generates a friendly SQLException informing the user of this.
        Throws:
        java.sql.SQLException
      • pushStreamableObjectPart

        public void pushStreamableObjectPart​(byte type,
                                             long object_id,
                                             long object_length,
                                             byte[] buf,
                                             long offset,
                                             int length)
                                      throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Pushes a part of a streamable object from the client onto the server. The server stores the large object for use with a future query. For example, a sequence of with a query with large objects may operate as follows;

         1) Push 100 MB object (id = 104)
         2) execQuery with query that contains a streamable object with id 104
         

        Note that the client may push any part of a streamable object onto the server, however the streamable object must have been completely pushed for the query to execute correctly. For example, an 100 MB byte array may be pushed onto the server in blocks of 64K (in 1,600 separate blocks).

        Specified by:
        pushStreamableObjectPart in interface DatabaseInterface
        Parameters:
        type - the StreamableObject type (1 = byte array, 2 = char array)
        object_id - the identifier of the StreamableObject for future queries.
        object_length - the total length of the StreamableObject.
        buf - the byte[] array representing the block of information being sent.
        offset - the offset into of the object of this block.
        length - the length of the block being pushed.
        Throws:
        java.sql.SQLException
      • execQuery

        public QueryResponse execQuery​(SQLQuery query)
                                throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Executes the query and returns a QueryResponse object that describes the result of the query. The QueryResponse object describes the number of rows, describes the columns, etc. This method will block until the query has completed. The QueryResponse can be used to obtain the 'result id' variable that is used in subsequent queries to the engine to retrieve the actual result of the query.
        Specified by:
        execQuery in interface DatabaseInterface
        Throws:
        java.sql.SQLException
      • getResultPart

        public ResultPart getResultPart​(int result_id,
                                        int row_number,
                                        int row_count)
                                 throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Returns a part of a result set. The result set part is referenced via the 'result id' found in the QueryResponse. This is used to read parts of the query once it has been found via 'execQuery'.

        The returned List object contains the result requested.

        If the result contains any StreamableObject objects, then the server allocates a channel to the object via the 'getStreamableObjectPart' and the identifier of the StreamableObject. The channel may only be disposed if the 'disposeStreamableObject' method is called.

        Specified by:
        getResultPart in interface DatabaseInterface
        Throws:
        java.sql.SQLException
      • disposeResult

        public void disposeResult​(int result_id)
                           throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Disposes of a result of a query on the server. This frees up server side resources allocated to a query. This should be called when the ResultSet of a query closes. We should try and use this method as soon as possible because it frees locks on tables and allows deleted rows to be reclaimed.
        Specified by:
        disposeResult in interface DatabaseInterface
        Throws:
        java.sql.SQLException
      • getStreamableObjectPart

        public StreamableObjectPart getStreamableObjectPart​(int result_id,
                                                            long streamable_object_id,
                                                            long offset,
                                                            int len)
                                                     throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Returns a section of a large binary or character stream in a result set. This is used to stream large values over the connection. For example, if a row contained a multi megabyte object and the client is only interested in the first few characters and the last few characters of the stream. This would require only a few queries to the database and the multi- megabyte object would not need to be downloaded to the client in its entirety.
        Specified by:
        getStreamableObjectPart in interface DatabaseInterface
        Throws:
        java.sql.SQLException
      • disposeStreamableObject

        public void disposeStreamableObject​(int result_id,
                                            long streamable_object_id)
                                     throws java.sql.SQLException
        Description copied from interface: DatabaseInterface
        Disposes a streamable object channel with the given identifier. This should be called to free any resources on the server associated with the object. It should be called as soon as possible because it frees locks on the tables and allows deleted rows to be reclaimed.
        Specified by:
        disposeStreamableObject in interface DatabaseInterface
        Throws:
        java.sql.SQLException
      • finalize

        public void finalize()
                      throws java.lang.Throwable
        Clean up if this object is GC'd.
        Overrides:
        finalize in class java.lang.Object
        Throws:
        java.lang.Throwable