--TEST-- Bug #32405 (mysqli->fetch() is returning bad data) --EXTENSIONS-- mysqli --SKIPIF-- <?php require_once('skipifconnectfailure.inc'); ?> --FILE-- <?php require_once("connect.inc"); /*** test mysqli_connect 127.0.0.1 ***/ $link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket); mysqli_select_db($link, "test"); mysqli_query($link, "SET sql_mode=''"); /* two fields are needed. the problem does not occur with 1 field only selected. */ $link->query("CREATE TABLE test_users(user_id int(10) unsigned NOT NULL auto_increment, login varchar(50) default '', PRIMARY KEY (user_id))"); $link->query('INSERT INTO test_users VALUES (NULL, "user1"), (NULL, "user2"), (NULL, "user3"), (NULL, "user4")'); if ($stmt = $link->prepare("SELECT SQL_NO_CACHE user_id, login FROM test_users")) { $stmt->execute(); $stmt->bind_result($col1, $col2); while ($stmt->fetch()) { var_dump($col1, $col2); } $stmt->close(); } mysqli_query($link,"DROP TABLE test_users"); mysqli_close($link); ?> --CLEAN-- <?php require_once("connect.inc"); if (!$link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket)) printf("[c001] [%d] %s\n", mysqli_connect_errno(), mysqli_connect_error()); if (!mysqli_query($link, "DROP TABLE IF EXISTS test_users")) printf("[c002] Cannot drop table, [%d] %s\n", mysqli_errno($link), mysqli_error($link)); mysqli_close($link); ?> --EXPECTF-- int(1) %s(5) "user1" int(2) %s(5) "user2" int(3) %s(5) "user3" int(4) %s(5) "user4"