NAME

DBIx::Compat - Perl extension for Compatibility Infos about DBD Drivers

SYNOPSIS

use DBIx::Compat;

$DBIx::Compat::Compat{$Driver}{Placeholders}  
$DBIx::Compat::Compat{$Driver}{QuoteTypes}  
$DBIx::Compat::Compat{$Driver}{ListFields}  

DESCRIPTION

DBIx::Compat contains a hash which gives information about DBD drivers, to allow to write driver independent programs.

Currently there are three attributes defined:

Placeholders

Gives information if and how placeholders are supported:

0 = Not supported
1 = Supported, but not fully, unknown how much
2 = Supported, but perl type must be the same as type in db
3 = Supported, but can not give a string when a numeric type is in the db
10 = Supported under all circumstances

QuoteTypes

Gives information which datatypes must be quoted when passed literal (not via a placeholder). Contains a hash with all type number which need to be quoted.

$DBIx::Compat::Compat{$Driver}{QuoteTypes}{$Type} 

will be true when the type in $Type for the driver $Driver must be quoted.

ListFields

A function which will return information about all fields of an table. Needs an database handle and a tablename as argument. Must at least return the fieldnames and the fieldtypes.

Example:
 
 $ListFields = $DBIx::Compat::Compat{$Driver}{ListFields} ;
 $sth = &{$ListFields}($DBHandle, $Table) or die "Cannot list fields" ;
   
 @{ $sth -> {NAME} } ; # array of fieldnames
 @{ $sth -> {TYPE} } ; # array of filedtypes

 $sth -> finish ;

Supported Drivers

Currently there are entry for

DBD::mSQL
DBD::mysql
DBD::Pg
DBD::Solid
DBD::ODBC
DBD::CSV
DBD::Oracle

if you detect an error in the definition or add an definition for a new DBD driver, please mail it to the author.

AUTHOR

G.Richter <richter*dev.ecos.de>

SEE ALSO

perl(1), DBI(3), DBIx::Recordset(3)

2 POD Errors

The following errors were encountered while parsing the POD:

Around line 319:

'=item' outside of any '=over'

Around line 337:

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