Question

This question already has an answer here:

I need to add values received from MySQL into an array [PHP], here is what I've got:

$players = array();

while ($homePlayerRow = mysql_fetch_array($homePlayerResult)) {
    $players[] = $homePlayerRow['player_id'];
}

Is this the only way of doing it? Also, is the following faster/better?

$players = array();

while ($homePlayerRow = mysql_fetch_array($homePlayerResult)) {
    array_push($players, $homePlayerRow['player_id']);
}

Thanks in advance

Was it helpful?

Solution

u can run and see that array_push is slower in some case

http://snipplr.com/view/759/speed-test-arraypush-vs-array/

run your code . enjoy

OTHER TIPS

Depends...

Documentation says,

"If you use array_push() to add one element to the array it's better to use $array[] = because in that way there is no overhead of calling a function."

Source: http://us2.php.net/array_push

So it boils down to how much data you want to cram into that array at any particular moment. Additionally, there's a fall-back, if the array-referenced doesn't exist when you call it using array_push, you'll bump an error. If you use $array[], the array will be created for you.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top