php - 如何将不同的论坛分组到 PHP 类别中

标签 php mysql forums

我想将我的论坛分组,如下所示:

enter image description here

我目前有一个名为 forum_categories 的数据库表,它有一个标题并为所有创建的类别创建一个 ID。我在名为 forum_forums 的数据库表中也有一列(我想分类的所有不同论坛),它采用名为 category_apart_of 的值。

我将如何在正确的类别 ID 中列出论坛?

非常感谢!

如果您想查看我的任何代码,或者希望我更深入地解释任何内容,请告诉我。

我当前用于列出论坛的代码(注意:获取所有论坛的 SQL 查询在上面):

<thead>
    <tr>
      <th style="width: 50%;">Forum</th>   
      <th style="width: 10%;">Threads</th> 
      <th style="width: 10%;">Posts</th>
      <th style="width: 30%;">Latest Posts</th>        
    </tr>
    </thead>
    <tbody> 
    <?php 
      while($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        $forumID = $row['forumID'];
        $forum_title[] = $row['forum_title'];
        $forum_description[] = $row['forum_description'];
        $forum_total_threads[] = $row['forum_total_threads'];
        $forum_total_posts[] = $row['forum_total_posts'];
        $forum_latest_thread[] = $row['forum_latest_thread'];

        $stmt2 = $db->prepare("SELECT * FROM forum_threads WHERE forum_thread_belongs_to = '$forumID'");
        $stmt2->execute();
        $count = $stmt2->rowCount();

        echo '
        <tr><td><h4 style="margin-bottom: 0px;"><a style="margin-bottom: 0px;" href="forum.php?id=' 
        . $row['forumID'] . ' ">'.$row['forum_title']
        . '</a></h4><br /><h6 style="margin-bottom: 0px; margin-top: 0px;">'
        .$row['forum_description'].'</h6></td><td style="text-align: center;><span">'.$count
        .'</span></td><td style="text-align: center;><span">'.$row['forum_total_posts']
        .'</span></td><td>'.$row['forum_latest_thread'].'</td></tr>
        ';
     }
    ?>
</tbody>

两个表的 DDL:

CREATE TABLE IF NOT EXISTS `forum_forums` (
`forumID` int(11) NOT NULL AUTO_INCREMENT,
`forum_title` varchar(255) NOT NULL,
`forum_description` varchar(255) NOT NULL DEFAULT 'This forum does not have      a description',
`forum_total_threads` int(255) NOT NULL DEFAULT '0',
`forum_total_posts` int(255) NOT NULL DEFAULT '0',
`forum_latest_thread` varchar(255) NOT NULL DEFAULT 'There are no new   threads',
`forum_apart_of` int(11) NOT NULL,
`category_apart_of` int(11) NOT NULL,
 PRIMARY KEY (`forumID`)
 ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

CREATE TABLE IF NOT EXISTS `forum_categories` (
`catID` int(11) NOT NULL AUTO_INCREMENT,
`cat_title` varchar(255) NOT NULL,
PRIMARY KEY (`catID`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

最佳答案

您的问题:我将如何在正确的类别 ID 中列出论坛?

解决方案: 因为你已经有了你的数据库结构,而且你已经并且应该知道,为了将你的 categories 表与你的 forums 表链接起来,你需要在两者中至少有一列类似的是 categories 表中的 category_id 自动递增列,即 id 所以为了将您的论坛归类到您需要的特定类别将类别 id 添加到 forums 表中的额外列作为 category_id 这样每个论坛都会在 id 值中提到它的类别。 .!

然后您可以像这样按类别列出您的论坛:

注意:此代码将检查每个论坛类别,并将列出每个类别下的所有论坛......!

<?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>";  
} 
?>

工作代码示例:

<?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>";  
} 
?>

输出:

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

关于php - 如何将不同的论坛分组到 PHP 类别中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37059624/

相关文章:

mysql - 将 .mdf 文件转换为 .sql 脚本 (mac)

twitter-bootstrap - 使用 Twitter Bootstrap 构建社区论坛

database - 刮一个phpbb论坛

django - 在博客文章中添加下一个/上一个按钮

php - jQuery/Ajax 请求被发送两次

php - 如何在 JSON 中为来自两个不同表的类别的选中 1 或 0 提供响应?

php - 从源代码编译PHP时为OpenSSL出错

mysql - 按日期分割复杂的mysql选择

php - Magento - 自动重定向到配置的支付网关之一

java - 如何将Recyclerview从最后一个ID到第一个ID排序?