I would like to propose a change in how mysqli_fetch() signifies "no more data." It should return NULL instead of MYSQLI_NO_DATA (a positive value) because it leads to cleaner PHP code and is more consistent with other MySQL fetch functions.
Currently, mysqli_fetch() returns one of three different values: Value | Meaning --------------------------------- true | Successful Fetch false | Error MYSQLI_NO_DATA | No more data --------------------------------- Returning the constant MYSQLI_NO_DATA (100) mimics the underlying MySQL C API, but it leads to non-natural PHP Code: while (MYSQLI_NO_DATA !== mysqli_fetch($db)) { // do something. } Every other MySQL function allows you to do: while ($row = mysqli_fetch_row($db)) { // do something. } And I think it'd be much nicer to allow people to write: while (mysqli_fetch($db)) { // do something. } Therefore, I propose that instead of returning MYSQLI_NO_DATA, we return NULL. Here's my reasoning: 1) The other mysqli_fetch_* functions now return NULL in this situation. 2) We're already modifying the MySQL C-level return values. In C, mysql_fetch() returns 0 on success and 1 upon an error. We've swapped these values to behave more PHP-like. 3) When 0 signifies success, a positive "no more data" error code makes sense because it looks (logically) like an error inside a while. That doesn't hold true now that we've flipped these values. -adam -- [EMAIL PROTECTED] author of o'reilly's php cookbook avoid the holiday rush, buy your copy today! -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php