diff options
| author | Matheus Degiovani <matheus@gigatron.com.br> | 2013-03-22 10:24:07 -0300 | 
|---|---|---|
| committer | Matteo Beccati <matteo@beccati.com> | 2013-05-31 14:30:51 +0200 | 
| commit | 65d233f06c6e274f9559880a7c187b35932b1918 (patch) | |
| tree | 595cd90819cb3393215f24af1f2ed157e6217586 | |
| parent | 1c623e3b07128e78362911ff5754e7eee57fa8bb (diff) | |
| download | php-git-65d233f06c6e274f9559880a7c187b35932b1918.tar.gz | |
Fixed bug #64037 (wrong value returned when using a negative numeric field equal to the scale)
| -rw-r--r-- | ext/pdo_firebird/firebird_statement.c | 2 | ||||
| -rw-r--r-- | ext/pdo_firebird/tests/bug_64037.phpt | 45 | 
2 files changed, 46 insertions, 1 deletions
| diff --git a/ext/pdo_firebird/firebird_statement.c b/ext/pdo_firebird/firebird_statement.c index 5c3e435f7b..ffe9b3cb63 100644 --- a/ext/pdo_firebird/firebird_statement.c +++ b/ext/pdo_firebird/firebird_statement.c @@ -344,7 +344,7 @@ static int firebird_stmt_get_col(pdo_stmt_t *stmt, int colno, char **ptr,  /* {{  			if (n >= 0) {  				*len = slprintf(*ptr, CHAR_BUF_LEN, "%" LL_MASK "d.%0*" LL_MASK "d",   					n / f, -var->sqlscale, n % f); -			} else if (n < -f) { +			} else if (n <= -f) {  				*len = slprintf(*ptr, CHAR_BUF_LEN, "%" LL_MASK "d.%0*" LL_MASK "d",  					n / f, -var->sqlscale, -n % f);				  			 } else { diff --git a/ext/pdo_firebird/tests/bug_64037.phpt b/ext/pdo_firebird/tests/bug_64037.phpt new file mode 100644 index 0000000000..f7b53e57a3 --- /dev/null +++ b/ext/pdo_firebird/tests/bug_64037.phpt @@ -0,0 +1,45 @@ +--TEST-- +Bug #64037 Firebird return wrong value for numeric field +--SKIPIF-- +<?php extension_loaded("pdo_firebird") or die("skip"); ?> +<?php function_exists("ibase_query") or die("skip"); ?> +--FILE-- +<?php + +require("testdb.inc"); + +$dbh = new PDO("firebird:dbname=$test_base",$user,$password) or die; +$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING); +$value = '2'; +@$dbh->exec('DROP TABLE price'); +$dbh->exec("CREATE TABLE PRICE (ID INTEGER NOT NULL, TEXT VARCHAR(10), COST NUMERIC(15, 2))"); +$dbh->exec("INSERT INTO PRICE (ID, TEXT, COST) VALUES (1, 'test', -1.0)"); +$dbh->exec("INSERT INTO PRICE (ID, TEXT, COST) VALUES (2, 'test', -0.99)"); +$dbh->exec("INSERT INTO PRICE (ID, TEXT, COST) VALUES (3, 'test', -1.01)"); + +$dbh->commit(); + +$query = "SELECT * from price order by ID"; +$stmt = $dbh->prepare($query); +$stmt->execute(); +$rows = $stmt->fetchAll(); +var_dump($rows[0]['COST']); +var_dump($rows[1]['COST']); +var_dump($rows[2]['COST']); + + +$stmt = $dbh->prepare('DELETE FROM price'); +$stmt->execute(); + +$dbh->commit(); + +$dbh->exec('DROP TABLE price'); + +unset($stmt); +unset($dbh); + +?> +--EXPECT-- +string(5) "-1.00" +string(5) "-0.99" +string(5) "-1.01"
\ No newline at end of file | 
