NAME

Oracle::Schema - Perl class for Oracle Schema Information and Management

SYNOPSIS

use Oracle::Schema;

my %cfg = ('conn_string'=>'usr/pwd@db');
my $os = Oracle::Schema->new;
# or combine the two together
my $os = Oracle::Schema->new('cs'=>'usr/pwd@db');
$os->display_objects; 

DESCRIPTION

This class includes methods to query (find, retrieve, and compare) objects in an Oracle schema and to manage (create, drop, update, merge, and move) Oracle objects.

new (cs=>'usr/pwd@db',tn=>'my_table')

Input variables:

$cs  - Oracle connection string in usr/pwd@db
$tn  - Oracle table name without schema

Variables used or routines called:

None

How to use:

my $obj = new Oracle::Schema;      # or
my $obj = Oracle::Schema->new;     # or
my $cs  = 'usr/pwd@db';
my $tn  = 'my_table'; 
my $obj = Oracle::Schema->new(cs=>$cs,tn=>$tn); # or
my $obj = Oracle::Schema->new('cs',$cs, 'tn',$tn); 

Return: new empty or initialized Oracle::Schema object.

This method constructs a Perl object and capture any parameters if specified. It creates and defaults the following variables:

$self->{conn_string} = "";       # or $self->{cs}
$self->{table_name}  = "";       # or $self->{tn}  

METHODS

The following are the common methods, routines, and functions defined in this class.

Exported Tag: All

The :all tag includes all the methods or sub-rountines defined in this class.

use Oracle::Schema qw(:all);

It includes the following sub-routines:

Table Methods

The :table tag includes sub-rountines for creating, checking and manipulating tables.

use Oracle::DML::Common qw(:table);

It includes the following sub-routines:

get_table_definition($dbh,$tn,$cns,$otp)

Input variables:

$dbh - database handler, required.
$tn  - table/object name, required.
       schema.table_name is allowed.
$cns - column names separated by comma.
       Default is null, i.e., to get all the columns.
       If specified, only get definition for those specified.
$otp - output array type:
       AR|ARRAY        - returns ($cns,$df1,$cmt)
       AH1|ARRAY_HASH1 - returns ($cns,$df2,$cmt)
       HH|HASH         - returns ($cns,$df3,$cmt)
       AH2|ARRAY_HASH2 - returns ($cns,$df4,$cmt)

Variables used or routines called:

echoMSG - display messages.

How to use:

($cns,$df1,$cmt) = $self->getTableDef($dbh,$table_name,'','array');
($cns,$df2,$cmt) = $self->getTableDef($dbh,$table_name,'','ah1');
($cns,$df3,$cmt) = $self->getTableDef($dbh,$table_name,'','hash');
($cns,$df4,$cmt) = $self->getTableDef($dbh,$table_name,'','ah2');

Return:

$cns - a list of column names separated by comma.
$df1 - column definiton array ref in [$seq][$cnn].
  where $seq is column sequence number, $cnn is array
  index number corresponding to column names:
        0 - cname,
        1 - coltype,
        2 - width,
        3 - scale,
        4 - precision,
        5 - nulls,
        6 - colno,
        7 - character_set_name.
$df2 - column definiton array ref in [$seq]{$itm}.
  where $seq is column number (colno) and $itm are:
        col - column name
        seq - column sequence number
        typ - column data type
        wid - column width
        max - max width
        min - min width
        dec - number of decimals
        req - requirement: null or not null
        dft - date format
        dsp - description or comments
$df3 - {$cn}{$itm} when $otp = 'HASH'
  where $cn is column name in lower case and
        $itm are the same as the above
$df4 - [$seq]{$itm} when $otp = 'AH2'
  where $seq is the column number, and $itm are:
        cname     - column name (col)
        coltype   - column data type (typ)
        width     - column width (wid)
        scale     - column scale (dec)
        precision - column precision (wid for N)
        nulls     - null or not null (req)
        colno     - column sequence number (seq)
        character_set_name - character set name
$cmt - {$cn}: contains comments for each column 

HISTORY

  • Version 0.01

    This version is to set the framework and move the get_table_definition from Oracle:;DML::Common.

  • Version 0.02

    Added table tag for export.

SEE ALSO (some of docs that I check often)

Data::Describe, Oracle::Loader, CGI::Getopt, File::Xcopy, perltoot(1), perlobj(1), perlbot(1), perlsub(1), perldata(1), perlsub(1), perlmod(1), perlmodlib(1), perlref(1), perlreftut(1).

AUTHOR

Copyright (c) 2005 Hanming Tu. All rights reserved.

This package is free software and is provided "as is" without express or implied warranty. It may be used, redistributed and/or modified under the terms of the Perl Artistic License (see http://www.perl.com/perl/misc/Artistic.html)

1 POD Error

The following errors were encountered while parsing the POD:

Around line 366:

You forgot a '=back' before '=head1'