2009-07-02 19 views
25

tengo que añadir los valores recibidos de MySQL en una matriz [PHP], aquí es lo que tengo:

$players = array(); 

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

¿Es esta la única manera de hacerlo? También, ¿es el siguiente más rápido/mejor?

$players = array(); 

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

Gracias de antemano

+0

Si solo estás accediendo a las claves asociativas (player_id) entonces es mejor utilizar 'mysql_fetch_assoc'. También podría usar 'mysql_fetch_row' luego' $ homePlayerRow [0] ', que es un poco más rápido. – DisgruntledGoat

Respuesta

24

Depende ...

documentación dice,

"Si utiliza array_push() para añadir un elemento a la matriz que es mejor use $ array [] = porque de esa manera no hay sobrecarga de llamar a una función ".

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

Por lo tanto, se reduce a la cantidad de datos que desea meter en esa matriz en cualquier momento en particular. Además, hay un retroceso, si la matriz de referencia no existe cuando lo llamas usando array_push, encontrarás un error. Si usa $ array [], la matriz se creará para usted.

+0

Al final decidí ir con matriz [] = ... ya que la matriz podría llegar a ser muy grande en algún momento –

+2

Creo que es más rápido declarar una matriz (con '$ arr = array()') antes de usar '$ arr [] = X'. También es útil si tus sentencias '$ arr []' están dentro de alguna lógica de control; todavía tienes una variable al final, una matriz sin elementos. – DisgruntledGoat

Cuestiones relacionadas