sql >> Database >  >> RDS >> Mysql

Hoe verschillende forums in categorieën te groeperen PHP

Uw vraag: Hoe kan ik de forums in hun juiste categorie-ID vermelden?

Oplossing: Aangezien u uw databasestructuur al heeft en zoals u al en waarschijnlijk zou moeten weten om uw categories te koppelen tabel met uw forums tabel moet u ten minste één kolom in beide vergelijkbare kolommen hebben, namelijk een category_id uit je categories tabel automatisch oplopende kolom namelijk als id dus om uw forum in de specifieke categorie te categoriseren, moet u de categorie id toevoegen naar een extra kolom als category_id in je forums tabel, zodat elk forum zijn categorie daarin vermeld heeft in id-waarde..!

En dan kun je je forums per categorie weergeven, zoals op deze manier:

Opmerking: Deze code controleert elke forumcategorie en geeft een lijst van al die forums onder elke categorie..!

<?php
//Assuming you have fetched whole data from forums table in $forums
//And whole data from categories in $categories
//So moving forward with the code

foreach ($categories  as $category) {
echo "<h1>".$category['category_title']."</h1>";
$category_id = $category['category_id'];
$query = mysqli_query($mysqli,"SELECT * FROM forums WHERE category_id='$category_id'");

$forums = array();
while ($rows = mysqli_fetch_array($query)) {
  $forums[] = $rows;
}

foreach ($forums as $forum) {
echo "Title :".$forum['forum_title']."</br>";
echo "Descripton :".$forum['forum_description']."</br></br></br>";
}
echo "</br></br></br></br>";  
} 
?>

VOORBEELD WERKCODE:

<?php
$categories = array(
    array('id' => "04",'category_title' => "News & Support"),
    array('id' => "23",'category_title' => "Current Affairs"),
    array('id' => "12",'category_title' => "Politics"));

    $forums = array(
    array('forum_title' => "News 1",'category_id' => "04"),
    array('forum_title' => "News 2",'category_id' => "04"),
    array('forum_title' => "Current Afairs 1",'category_id' => "23"),
    array('forum_title' => "Current Afairs 2",'category_id' => "23"),
    array('forum_title' => "Politics 1",'category_id' => "12"),
    array('forum_title' => "Politics 2",'category_id' => "12")); 

foreach ($categories  as $category) {
echo "<h1>".$category['category_title']."</h1>";
$category_id = $category['id'];
$output = array();
for ($i=0;$i<=count($forums);$i++) {
if  ($category_id == $forums[$i]['category_id']) {
$add_forum = array('forum_title' => $forums[$i]['forum_title'],'category_id' => $forums[$i]['category_id']);
array_push($output, $add_forum);
}
}
for ($i=0;$i<=count($output);$i++) {
echo "Title :".$output[$i]['forum_title']."</br>";
}
echo "</br></br></br></br>";  
} 
?>

UITVOER :

News & Support

Title :News 1
Title :News 2


Current Affairs

Title :Current Afairs 1
Title :Current Afairs 2


Politics

Title :Politics 1
Title :Politics 2



  1. Voordelen van pdo boven mysql_* of mysqli_*

  2. mysql-tabel bijwerken met waar-parameter uit jtable-cel

  3. MySQL Query om te groeperen op datumbereik?

  4. Tabellen verwijderen uit database Oracle 10g