NAME
    DBGUI - a Sybase database server graphical interface.

DESCRIPTION
    DBGUI features:

        Perform any SQL command.

        Save the SQL results to a file.

        Perform incremental or standard searches or the SQL results.

        Keep a history of _all_ SQL commands and parameters.

        Sort (normal, numerical and reverse) on any column of the SQL results.

        Sum up the numeric values in any data column
        
        Print the SQL results to a printer.

        Quick command line clear and restore for easy command line generation/pasting.

        "Clone" the results to a new display window for comparisons etc.

        Utilize the SYBASE libraries or isql/sqsh binaries for the queries.

        Maintain four complete configuration "snapshots" for easy retrieval.

        Reload the last set of parameters on startup.

        Interactively enable and disable any or all of three different command lines for
        execution. All of the 'active' command lines are concatenated, therefore the three
        command entry lines can be used to quickly eliminate/add command parameters to an
        existing command.

        Display the column data type in each column header.

        Display the column data width in each column header.

        Solicit and quickly popup a list of the system datatypes.

        Colored busy indicator (red/green) to indicate if the DBGUI is waiting on results
        from the DB server.

        The date/time of command execution is captured in the title bar.

        A checkpoint filename can be specified as an argument.   This allows the user to maintain
        separate or pre-defined menu histories for all menus in dbgui.
        
        The loaded checkpoint file is captured in the title bar.
        
        Color coded headers for multiple resultset data.
        
        More probably.... :-)

PREREQUISITES
    This script requires the following Perl Modules:

        'Tk Toolkit'

        'DBI' $CPAN/authors/id/TIMB
        
        'DBD' (for your particular type of database server  sybase,oracle etc..) 
            ex - for Sybase the module is: $CPAN/authors/id/MEWP/DBD-Sybase-xxx.tar.gz
             
        
        Note for Sybase:DBD users, Michael Peppler (author of the DBD:Sybase module)
            has graciously furnished me with a pre-released version 0.20 of his DBD:sybase
            module.  A change was made in this module which affects the column width data
            extracted from Sybase.  Without this change, some columns (with a binary data
            type or numeric) will have a different column width than the actual column width 
            definition in the database table.   Since the column widths are longer than the
            data and not shorter, the problem is mostly cosmetic (except for the value reported 
            in the column header for the column width)..   Hopefully version 0.20 will be
            in wide release soon.  
        
        'Sort::Fields' $CPAN/authors/id/JNH/Sort-Fields-xxx.tar.gz

        'Tk::HistEntry'  $CPAN/authors/id/SREZIC/Tk-HistEntry-xxx.tar.gz

        'Tk::PrintDialog' (not on CPAN but included with this distro)

    CPAN/Administrative Fun/Educational

Startup:
   dbgui.pl <ret> (to load the default ~/.dbgui checkpoint file)
   dbgui.pl [checkpoint file] (to load  a checkpoint file in the local directory or the home
      directory.  (in that order).  You can run dbgui multiple instances of dbgui, each with
      its own checkpoint file (if you wish).   This allows the user to have separate command
      histories for different servers.

The Buttons/HistEntrys:
(From left to right, top to bottom)

Server entry - Allows the user to enter or select the DB server to connect with.  If a new 
   server name is entered into the entry, the server is added to the server history list. 
   A history of 60 entries is maintained.

Username entry - Allows the user to enter or select the Sybase user to connect with.  
   If a new user name is entered into the entry, the user is added to the user history list. 
   A history of 60 entries is maintained.

Password entry - Allows the user to enter or select the password to connect with.  If a new 
   password is entered into the entry, the server is added to the password history list. 
   A history of 60 entries is maintained.

Use DB entry - Allows the user to enter or select the database to connect to once a 
   connection is established to the server.  If a new database is entered into the entry, 
   the database is added to the database history list. 
   A history of 60 entries is maintained.

Max Rows entry - Allows the user to set the maximum rowcount for the db query/command.  
   If 0 is used, no max rowcount will be set.  A "hidden" feature of this entry is if Mouse
   button three is clicked, the value of maxrows is cycled from zero, 20, and any already
   entered value (if it exists).  

Snapshot slider - Allows the user to select and load "snapshots" of command parameters.  
   Four snapshots can be saved.  Snapshot 0 is automatically loaded and is always 
   configured to be the command configuration last used when dbgui was exited.   If the 
   user has several commands on different servers he has to call frequently, a snapshot 
   can be made once the command parameters are entered, and can be instantly retrieved by
   selecting that particular snapshot at any time.

Busy LED - This circular button changes color to indicate a busy or idle state.

Method menubutton - Allows the user to enter or select the method which is used to interface 
   with the database server.  "Sybase" uses the sybase libraries API.  Isql and Sqsh are 
   binaries that are called to execute the command.  The output of these binaries is
   less elegant and informative than using the sybase libraries.  The isql and sqsh 
   options were actually originally implemented to prove to doubting co-workers who 
   tended to blame dbgui if unexpected results were returned from a query.  It worked :-)

Timeout slider - The timeout slider is used to set the timeout (IN SECONDS) for an executing
   command.  
   NOTE - If no data has yet to be returned from the executing command when the timer expires,
      the DBGUI utility has no access to the process to terminate it.  Basically it is locked
      out.  If data is being returned, then DBGUI has the opportunity to cancel the executing
      command and process the already returned result sets..
   
CTR buttons - The "Clear Trim Restore" buttons (there is one for each command line) is used 
   to quickly 1. clear the entire associated command entry before data is entered or pasted.  
   2. trim off the last element of the associated command , or 3. Restore the associated
   command from the last "CTR" operation.  These were implemented  because I am constantly 
   copying a command to the X clipboard from another window and wanting to paste the command 
   into the dbgui command entries.  Since these entries usually had a previous command already 
   in them, I would have to paste the command in, and then delete old command from the command 
   entry...   a real pain...   Now with a click of mouse button one the command line is 
   cleared and ready to be written into.  Mouse button two will chop off the last element on
   the command line. Mouse button three will restore the command entry if you have accidentally 
   cleared the wrong command one.
   
Sel buttons - The Sel buttons sets the associated command entry as 'active'.  If a command
   entry is not active, it wont be executed, and the command entry text will be grayed out.
   If a command entry is set to active the command line will be executed when the execute 
   button is pressed or return is entered.  Note - all three command entries operate 
   independently, you can have one active or all three.  If more than one command entry is
   active, each of the active command entry strings are concatenated together to form a 
   single sql command before executing.   This allows quick an easy command parameter 
   modifications by putting command options on different command entry lines and enabling
   or disabling the entries to change the sql command to execute. 

The Command Entries - These are the aforementioned commend entries used to formulate the
   sql command before execution.  A history of 60 entries is maintained.

The sql display pane - This is the sql output display pane.  Once a sql command is executed,
   the results (or errors) are displayed in this window.  The display pane has a top 
   header which will display each column name, data type (in brackets), and column width.
   Note - if more than one result set is returned by your sql command, no header will be
   displayed, and the multiple result sets will be displayed in the output pane.
   

Rows: label - This displays the rowcount of the executed command.

Cols: label - This displays the column count of the executed command.

Sum button - Attempts to sum up all of the values in the sorted column and display the results.
   If non-numeric data is encountered "N/A" is displayed for the total.

Sort button - This executes the sort function on the selected column.  A "hidden" feature of 
   the sort label is if mouse button three is clicked, sorting will be disabled for the next 
   command executed. Once a second command executed, the sort status is restored to normal. 
   Mouse button one restores the default sort status.

Sortby Menubutton - This selects the column to use for the sort function.

Rev radiobutton - Sets the sort to be a reverse sort.

Num radiobutton - Sets the sort to be a numeric sort.


Exec button - Executes the current sql command.

Snap button - Creates command "snapshots" for the current command.  Used by the snapshot
   selection slider at the top of the window to load a saved shapshot.

Clone button - Generates a second window containing the current sql output.  It allows the 
   user to spawn a second display of the data in order to continue executing sql commands,
   and still have the cloned data available for comparisons etc..
   
Save button - Saves the current sql data and parameters (except for the db password) to a 
   text file.

Print button - Sends the displayed sql output to a printer.  Calls PrintDialog.pm, which
   at this time is not on CPAN (but supposedly will be submitted soon).  I have included
   the module in this archive to make it easier to find.
   
Search button - Allows the user to search (incrementally or normally) on the sql output.

Exit button - Terminates the application and records the current configuration to be loaded
   the next time dbgui is executed.
   


-------

The DBGUI archive contains this file, the dbgui.pl script and a PrintDialog.pm perl 
module which is used to send the sql results to a printer.   Until this module is uploaded
to CPAN, (hopefully soon) I will include it in this archive.

Note - the PrintDialog.pm file has been renamed in this archive to PrintDialog.module
to prevent PAUSE automatic processing from posting PrintDialog as one of my own modules.
This file merely needs to be renamed to PrintDialog.pm and installed on your system.


-------

Thats pretty much it...

I hope you like DBGUI.  I use it every day... It has made my life a lot easier..

DBGUI can be fetched from your local CPAN site - 
   $CPAN/authors/id/M/MS/MSCROGGIN 
   
or my home page - 
   http://home.swbell.net/mscroggi/

I can be contacted via my webpage or at 
   mscroggi@swbell.net

Ciao

Monty