ID:               45237
 User updated by:  phpbugs at phormix dot com
 Reported By:      phpbugs at phormix dot com
 Status:           Bogus
 Bug Type:         MySQL related
 Operating System: FreeBSD
 PHP Version:      5.2.6
 New Comment:

Just to clarify this, if it were caused by a bad join, would it not
also mean that array[0] should be NULL, as well as the aliased
array[userid2]?


Previous Comments:
------------------------------------------------------------------------

[2008-06-11 16:39:38] phpbugs at phormix dot com

OK, this seems like odd behavior to me then, and not a JOIN-related
issue because of the following:

a) The value in question is part of the primary selected table (user)
and not one of the joined fields

b) Other values in this table are returning properly

c) The second variable, userid2, is the SAME field, but just aliased to
a new name using "user.userid as userid2"

d) The values return fine when using a numeric array, it is only
through the name of the associative array that it doesn't work


So perhaps I'm being dumb. This isn't my query (it's part of a
bulletin-board system), but I can't find any reasons, given the above,
that it should be returning results in this manner, and I've been
working with PHP+MySQL for quite awhile.

------------------------------------------------------------------------

[2008-06-11 13:41:09] [EMAIL PROTECTED]

var_dump, not vardump, sorry for that

------------------------------------------------------------------------

[2008-06-11 13:40:28] [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

you're using left joins, therefore you get NULL values. Use vardump()
instead of print_r() to get the the information.

------------------------------------------------------------------------

[2008-06-11 13:34:58] phpbugs at phormix dot com

Please note that the "expected" result should actually be:

Array ( [0] => 22768 [userid] => 22768 [1] => 22768 [userid2] => 22768
[2] =>
10 [reputation] => 10 [3] => jdoe [username] => jdoe [4] ... etc

------------------------------------------------------------------------

[2008-06-11 13:33:54] phpbugs at phormix dot com

Description:
------------
mysql_fetch_assoc does not return certain values attached to their
named items in the array. mysql_fetch_array shows that the numbered
entries definitely have values attached to them, but for some reason
these are not being attached to the appropriate names.

For example, as below. The first field is "userid"
array[0] returns a value
array[userid] does not

however, when adding code to the query "userid as userid2"
array[0] returns a value
array[userid] does not
array[1] returns a value
array[userid2] returns a value

Reproduce code:
---------------
$myquery = "SELECT user.userid, user.userid as userid2, reputation,
username, usergroupid, birthday_search, email, parentemail,(options & 8)
AS coppauser, homepage, icq, aim, yahoo, msn, skype, signature,
usertitle, joindate, lastpost, posts, ipaddress, lastactivity,
userfield.* FROM user LEFT JOIN userfield AS userfield
ON(userfield.userid = user.userid) LEFT JOIN usertextfield AS
usertextfield ON(usertextfield.userid = user.userid) WHERE 1=1 AND
user.username LIKE '%jdoe%' ORDER BY username ASC LIMIT 0, 50";

$user_r = mysql_query($myquery);
print_r( mysql_fetch_array($user_r) );




Expected result:
----------------
Array ( [0] => 22768 [userid] => [1] => 22768 [userid2] => 22768 [2] =>
10 [reputation] => 10 [3] => jdoe [username] => jdoe [4] ... etc

Actual result:
--------------
Array ( [0] => 22768 [userid] => [1] => 22768 [userid2] => 22768 [2] =>
10 [reputation] => 10 [3] => jdoe [username] => jdoe [4] ... etc

(please note the missing userid)


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=45237&edit=1

Reply via email to