Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

[PHP-DEV] pdo and firebird connection

239 views
Skip to first unread message

Michael Maier

unread,
Mar 12, 2005, 2:38:33 PM3/12/05
to
Hi,

I´ve trying now for hours just to connect with PDO to my firebird DB.
I tried it first with a mysql db and had no problems at all. but it
doesn´t work with firebird and I don´t know why (haven´t found anything
helpful via google as well).

I tried to use the manual from here:
http://de3.php.net/manual/de/function.pdo-construct.php

with the code below, I get always the error message:
Fatal error: Call to a member function getAttribute() on a non-object in
K:\_workspace\test1\pdo3.php on line 7

a test with the interbase driver works well (see in the code comments).

=> is the code correct?
=> where is the error!?
=> does the PDO firebird driver work?

thx a lot for help,

Michael

<?php
$username = 'SYSDBA';
$password = 'xxxxxx';

$dbh = new PDO(
'firebird:User=SYSDBA;Password=xxxxxx;Database=k:\_firebird\examples\EMPLOYEE.FDB;DataSource=localhost;Port=3050',
$username, $password );
//$dbh = new PDO(
'firebird:User=SYSDBA;Password=xxxxxx;Database=k:\_firebird\examples\EMPLOYEE.FDB;DataSource=localhost;Port=3050'
);
print $dbh->getAttribute(PDO_ATTR_AUTOCOMMIT); // <==Fatal error here!
$stmt = $dbh->prepare("Select * from SHOW_LANGS('SRep',4,'Italy')");
$stmt->execute();
$stmt = null;

/*
// test with ibase driver
$dsn = 'localhost:k:\_firebird\examples\employee.fdb';
$dbh = ibase_connect ( $dsn, $username, $password ) or die ("error in db
connect");
$stmt="Select * from SHOW_LANGS('SRep',4,'Italy')";
$query = ibase_prepare($stmt);
$rs=ibase_execute($query);
$row = ibase_fetch_row($rs);
echo $row[0];
// free result
ibase_free_query($query);
//ibase_free_result($rs);
// close db
ibase_close($dbh);
*/

?>

--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Michael Maier

unread,
Mar 13, 2005, 11:35:16 AM3/13/05
to

ok, for everybody who is playing with the pdo firebird driver as well:

----------------------
do for example the connection like this (not like the link to the manual
from above):
<?php
$user = "SYSDBA";
$password = "xxx";
$test_base = "localhost:k:\x_test\PDO\TEST.FDB";
$dbh = new PDO("firebird:dbname=$test_base",$user,$password) or die;
?>
----------------------
try catch doesn´t work (no exception is thrown):
<?php
...
try
{
$db = new PDO("firebird:dbname=$test_base",$user,$password);
}
catch( PDOException $e )
{
die( $e->getMessage() );
}
?>
----------------------
all the other examples form http://netevil.org/node.php?nid=44&SC=1 have
worked.
but be careful with the column named "value". better use a different
name e.g. "val" or whatever (I´ve had problems here).
----------------------

like Lester said, Ard is busy right now.
but he told me he will take some time in the near future to fix the
current issues.

thx,
Michael

0 new messages