- PDO_DBlib:
. Fixed bug #73234 (Emulated statements let value dictate parameter type).
(Adam Baratz)
+ . Fixed bug #73396 (bigint columns are returned as strings).
- SOAP:
. Fixed bug #69137 (Peer verification fails when using a proxy with SoapClient)
data_len = dbdatlen(H->link, colno+1);
if (data_len != 0 || data != NULL) {
- if (stmt->dbh->stringify) {
+ /* force stringify if DBBIGINT won't fit in zend_long */
+ /* this should only be an issue for 32-bit machines */
+ if (stmt->dbh->stringify || (coltype == SQLINT8 && sizeof(zend_long) < sizeof(DBBIGINT))) {
switch (coltype) {
case SQLDECIMAL:
case SQLNUMERIC:
case SQLMONEYN:
case SQLFLT4:
case SQLFLT8:
+ case SQLINT8:
case SQLINT4:
case SQLINT2:
case SQLINT1:
break;
}
+ case SQLINT8: {
+ zv = emalloc(sizeof(zval));
+ ZVAL_LONG(zv, *(DBBIGINT *) data);
+
+ break;
+ }
case SQLINT4: {
zv = emalloc(sizeof(zval));
- ZVAL_LONG(zv, (long) ((int) *(DBINT *) data));
+ ZVAL_LONG(zv, *(DBINT *) data);
break;
}
case SQLINT2: {
zv = emalloc(sizeof(zval));
- ZVAL_LONG(zv, (long) ((int) *(DBSMALLINT *) data));
+ ZVAL_LONG(zv, *(DBSMALLINT *) data);
break;
}
case SQLINT1:
case SQLBIT: {
zv = emalloc(sizeof(zval));
- ZVAL_LONG(zv, (long) ((int) *(DBTINYINT *) data));
+ ZVAL_LONG(zv, *(DBTINYINT *) data);
break;
}
--- /dev/null
+--TEST--
+PDO_DBLIB: bigint columns are returned as strings
+--SKIPIF--
+<?php
+if (!extension_loaded('pdo_dblib')) die('skip not loaded');
+require dirname(__FILE__) . '/config.inc';
+?>
+--FILE--
+<?php
+require dirname(__FILE__) . '/config.inc';
+
+// on 64-bit machines, these columns should come back as ints
+// on 32-bit machines, they will come back as strings because zend_long isn't big enough
+$expected = PHP_INT_SIZE == 8 ? 1 : '1';
+
+$stmt = $db->query('SELECT CAST(1 AS bigint)');
+var_dump($stmt->fetchColumn() === $expected);
+?>
+--EXPECT--
+bool(true)