1--TEST-- 2PDO_DBLIB: bigint columns are returned as strings 3--SKIPIF-- 4<?php 5if (!extension_loaded('pdo_dblib')) die('skip not loaded'); 6require __DIR__ . '/config.inc'; 7if (in_array($db->getAttribute(PDO::DBLIB_ATTR_TDS_VERSION), ['4.2', '4.6', '5.0', '6.0', '7.0'])) die('skip bigint type is unsupported by active TDS version'); 8?> 9--FILE-- 10<?php 11require __DIR__ . '/config.inc'; 12 13// on 64-bit machines, these columns should come back as ints 14// on 32-bit machines, they will come back as strings because zend_long isn't big enough 15$expected = PHP_INT_SIZE == 8 ? 1 : '1'; 16 17$stmt = $db->query('SELECT CAST(1 AS bigint)'); 18var_dump($stmt->fetchColumn() === $expected); 19?> 20--EXPECT-- 21bool(true) 22