NAME

DBD::IB - DBI driver for InterBase RDBMS server

SYNOPSIS

use DBI;

$dbpath = '/home/edwin/perl_example.gdb';
$dsn = "DBI:IB:database=$dbpath;host=puskom-4";

$dbh = DBI->connect($dsn, '', '', {AutoCommit => 0}) 
  or die "$DBI::errstr";

$dbh = DBI->connect($dsn, '', '', {RaiseError => 1}) 
  or die "$DBI::errstr";

$sth = $dbh->prepare("select * from SIMPLE") or die $dbh->errstr;
$sth->execute;

while (@row = $sth->fetchrow_array))
{
  print @row, "\n";
}

$dbh->commit or warn $dbh->errstr;
$dbh->disconnect or warn $dbh->errstr;  

For more examples, see eg/ directory.

DESCRIPTION

This DBI driver currently is a wrapper around IBPerl, written in pure perl. It is based on the DBI 1.13 specification dan IBPerl 0.7. This module should obsoletes the DBIx::IB.

Connecting with InterBase-specific optional parameters

InterBase allows you to connect with specifiying Role, Protocol, Cache, and Charset. These parameters can be passed to InterBase via $dsn of DBI connect method. Eg:

$dsn = 'dbi:IB:database=/path/to/data.gdb;protocol=IPX/SPX';

PREREQUISITE

  • InterBase client

  • IBPerl 0.7, by Bill Karwin

Both are available at http://www.interbase.com/, for more information, read the documentation of IBPerl.

INSTALLATION

Run:

# perl Makefile.PL

Here you will be prompted with some questions due to the database that will be used during 'make test'.

# make
# make test (optional)

The database you specify when running Makefile.PL should has been existed before running 'make test', otherwise you will get 'Invalid DBI handle -1' error message.

# make install

WARNING

InterBase specific behaviour:

  • $sth->{NAME} available after the first fetch

  • $sth->{NUM_OF_FIELDS} available after the first fetch

  • $dbh->do() doesn't return number of records affected

  • $sth->execute() doesn't return number of records

TESTED PLATFORMS

This module has been tested on Linux (2.0.33, 2.0.34), IBPerl 0.7, Perl 5.004_04, to access InterBase 4.0 for Linux, and InterBase 5.5 for NT.

KNOWN BUGS

This sequence won't work:

$dbh->do($stmt); #any statement on table TBL
$dbh->commit;
$dbh->do("drop table TBL");

Workaround: Change the commit with disconnect, and then connect again. This bug occurs at IBPerl level. Try some examples in eg/ibperl directory.

BUG REPORTS

Please send any bug report to dbi-users mailing list (http://www.isc.org/dbi-lists.html) Any bug report should be accompanied with the script that got the problem, and the output of DBI trace method.

HISTORY

Version 0.02, July 31, 1999

Alpha code. Major enhancement from the previous pre-alpha code. Previous known problems have been fixed. AutoCommit attribute works as expected.

Version 0.01, July 23, 1999

Pre-alpha code. An almost complete rewrite of DBIx::IB in pure perl. Problems encountered during handles destruction phase.

DBIx::IB Version 0.01, July 22, 1999

DBIx::IB, a DBI emulation layer for IBPerl is publicly announced.

TODO

  • Rigorous test under mod_perl and Apache::DBI

  • An xs version should be much powerful, and simplify the installation process.

ACKNOWLEDGEMENTS

Bill Karwin - author of IBPerl, Tim Bunce - author of DBI.

AUTHOR

Copyright (c) 1999 Edwin Pratomo <ed.pratomo@computer.org>.

All rights reserved. This is a free code, available as-is; you can redistribute it and/or modify it under the same terms as Perl itself.

SEE ALSO

DBI(3), IBPerl(1).