Edit report at https://bugs.php.net/bug.php?id=55291&edit=1
ID: 55291
Comment by: brandonkirsch at gmail dot com
Reported by: brandonkirsch at gmail dot com
Summary: All ODBC Queries Return INTs as Strings For Multiple
ODBC Drivers
Status: Not a bug
Type: Bug
Package: ODBC related
Operating System: SUSE SLES 10 SP2
PHP Version: 5.3.6
Block user comment: N
Private report: N
New Comment:
FYI - For those of you still struggling with this "Not a bug" - there are
functions available (odbc_field_type, mssql_field_type) that can help you
re-cast
your database numerics back to their correct types in PHP.
Previous Comments:
------------------------------------------------------------------------
[2012-02-07 08:50:56] martijntje at martijnotto dot nl
I have no idea why this bug is closed as bogus.
The current behavior is wrong for many reasons:
- Higher memory usage (can be problematic with big datasets)
- This forces one to use is_numeric instead of is_int, is_float, etc (much
slower)
- Removed the option for strict comparison: "1" === 1 => false
------------------------------------------------------------------------
[2011-12-01 05:35:08] [email protected]
Thank you for taking the time to write to us, but this is not
a bug. Please double-check the documentation available at
http://www.php.net/manual/ and the instructions on how to report
a bug at http://bugs.php.net/how-to-report.php
Most database layers convert numeric values to strings to preserve their
precision as PHP does not support all numeric precisions which a database might
(i.e. 64 bit integers). Since strings may be silently converted to numeric in
PHP ("1" + 2 = 3), this should not pose too much of an issue.
------------------------------------------------------------------------
[2011-07-26 21:44:49] brandonkirsch at gmail dot com
Description:
------------
odbc_* and PDO ODBC functions are each returning SQL integer values as PHP
strings. However, SQL NULL values properly appear as PHP NULL values.
I have tested against multiple ODBC providers (FreeTDS and iSeries Access for
Linux).
System:
SUSE Enterprise Linux Server 10 (SP2) - 32bit
Linux dev-webhost1 2.6.16.60-0.42.5-default #1 Mon Aug 24 09:41:41 UTC 2009
i686
i686 i386 GNU/Linux
UnixODBC
PHP 5.3.6 from source
./configure --with-apxs2=/usr/local/apache2/bin/apxs --with-
mssql=/usr/local/freetds --with-ldap --prefix=/usr/local/php5 --with-config-
file-
path=/usr/local/php5/etc --enable-sockets --enable-soap --with-openssl --with-
unixODBC=/usr --with-gd --with-jpeg-dir=/usr/lib --with-pdo-odbc=unixODBC,/usr
Test script:
---------------
1. odbc_* against FreeTDS to SQL Server 2008:
$odbc = odbc_connect('hpsql3','--censored--','--censored--');
$or = odbc_exec($odbc,'SELECT 1');
var_dump(odbc_fetch_array($or)); // array( string "1" )
2. odbc_* against iSeries Access for Linux to AS/400:
$odbc = odbc_connect('iSeriesDSN','--','--');
$or = odbc_exec($odbc,'SELECT 1 FROM SYSIBM.SYSDUMMY1');
var_dump(odbc_fetch_array($or)); // array( string "1" )
3. PDO against FreeTDS to SQL Server 2008
$pdo = new PDO('odbc:hpsql3','--','--');
var_dump($pdo->query('SELECT 1')->fetch(PDO::FETCH_ASSOC)); // array (string
"1")
4. PDO against iSeries Access for Linux to AS/400
$pdo = new PDO('odbc:iSeriesDSN','--','--');
var_dump($pdo->query('SELECT 1 FROM
SYSIBM.SYSDUMMY1')->fetch(PDO::FETCH_ASSOC)); // array (string "1")
Expected result:
----------------
I expect to get arrays containing (int) 1
Actual result:
--------------
I actually get arrays containing (string) "1"
------------------------------------------------------------------------
--
Edit this bug report at https://bugs.php.net/bug.php?id=55291&edit=1