Mysql
 sql >> Database >  >> RDS >> Mysql

Più tabelle MySQL a json_encode

Ok, ho scritto la tua soluzione. Devi essere sicuro che l'ordine di sia incluso lì perché presuppone che li stai ordinando con gli articoli insieme. Inoltre, non sapevo come fosse archiviato il tuo editore, quindi l'ho separato in una tabella separata (questo ti consentirà di ottenere gli articoli anche dal solo editore), che ora è 4 join. Anche su un'altra nota l'ho aggiornato per fare anche inner join. In questo modo non otterrai risultati vuoti per le console a cui non sono assegnati giochi. Se vuoi questi puoi semplicemente cambiare i join in modo che ti dia anche quei risultati. Fammi sapere se questo aiuta

//get all of the information
$query = '
    SELECT c.consoleId,c.consoleName,m.modelId,m.modelName,g.gameId,g.gameName,p.publisherId,p.publisherName
    FROM `consoleconsole` c
        INNER JOIN `consolemodel` m ON c.consoleId=m.consoleId
        INNER JOIN `consolegame` g ON m.modelId=g.modelId
        INNER JOIN `consolepublisher` p ON g.publisherId = p.publisherId
    ORDER BY c.consoleName, m.modelName, g.gameName
';

//get the results
$result = mysql_query($query);

//setup array to hold information
$consoles = array();

//setup holders for the different types so that we can filter out the data
$consoleId = 0;
$modelId = 0;

//setup to hold our current index
$consoleIndex = -1;
$modelIndex = -1;

//go through the rows
while($row = mysql_fetch_assoc($result)){
    if($consoleId != $row['consoleId']){
        $consoleIndex++;
        $modelIndex = -1;
        $consoleId = $row['consoleId'];

        //add the console
        $consoles[$consoleIndex]['console'] = $row['consoleName'];

        //setup the information array
        $consoles[$consoleIndex]['information'] = array();
    }

    if($modelId != $row['modelId']){
        $modelIndex++;
        $modelId = $row['modelId'];

        //add the model to the console
        $consoles[$consoleIndex]['information'][$modelIndex]['model'] = $row['modelName'];

        //setup the title array
        $consoles[$consoleIndex]['information'][$modelIndex]['title'] = array();
    }

    //add the game to the current console and model
    $consoles[$consoleIndex]['information'][$modelIndex]['title'][] = array(
        'game'      => $row['gameName'],
        'publisher' => $row['publisherName']
    );
}

echo json_encode($consoles);