如何在类别页面中获取多个类别帖子?

纳德-J

我正在开发自定义 CMS。我的问题是我有一个帖子有两个类别“教程”和“语言”。我想将其显示为类别页面中的项目。

这是我的 book_category 表 在此处输入图片说明

这是我的书桌。 在此处输入图片说明

问题 1:如何将书籍存储在具有多个类别的数据库中?我应该将类别 ID 作为字符串值存储在数据库中吗?

问题二:如何查询多分类的帖子?

这是我的 header.php 代码

<?php  include 'includes/db.php'; ?>
<html lang="fa-IR" dir="rtl">
   <head>
      <title>CMS کتابخانه</title>
      <script type="text/javascript" src="./assets/js/jquery.min.js"></script>
      <script type="text/javascript" src="./assets/js/bootstrap.js"></script>
      <link rel="stylesheet" href="./assets/css/bootstrap.min.css" type="text/css" >
      <link rel="stylesheet" href="./assets/css/bootstrap.rtl.min.css" type="text/css" >
      <link rel="stylesheet" href="./assets/css/main.css" type="text/css" >
      <link href="./assets/css/fontawesome-all.min.css" rel="stylesheet">
   </head>
   <body>
      <nav class="navbar navbar-expand-lg navbar-dark bg-dark">
        <a class="navbar-brand" id="logo" href="#">کتابخانه من</a>
        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
          <span class="navbar-toggler-icon"></span>
        </button>
        <div class="collapse navbar-collapse" id="navbarNav">
          <ul class="navbar-nav">
            <li class="nav-item <?php if($_SERVER['REQUEST_URI'] == '/cms/' || $_SERVER['REQUEST_URI'] == '/cms/index.php' ){echo 'active';} ?>">
              <a class="nav-link" href="index.php">خانه <span class="sr-only"></span></a>
            </li>
            <li class="nav-item dropdown">
              <a class="nav-link dropdown-toggle" href="#" id="navbardrop" data-toggle="dropdown">
               دسته بندی
              </a>
              <div class="dropdown-menu">
            <?php 
               $select_cat = mysqli_query($connection,"SELECT * FROM book_category");
                while($row = mysqli_fetch_array($select_cat)) {

                if(isset($_GET['category_name'])){
                  if($_GET['id'] == $row['category_id']){
                     $class='active';
                  }else{
                     $class='';
                  }
                }else{
                  $class='';
                }
                echo '<a class="dropdown-item '.$class.'" href="book_category.php?id='.$row['category_id'].'">'.$row['category_name'].'</a>';
                }
            ?>

              </div>
            </li>
            <li class="nav-item">
              <a class="nav-link" href="#">داغ ترین ها</a>
            </li>
            <li class="nav-item">
              <a class="nav-link" href="#">نویسندگان</a>
            </li>
            <?php if(!isset($_SESSION['user'])) : ?>
            <li class="nav-item">
              <a class="nav-link" href="register.php">عضویت</a>
            </li>
            <?php endif; ?>
          </ul>
        </div>
      </nav>
      <div class="p-2"></div>

这是我的 category.php 用于显示特定类别的帖子。

<?php include 'includes/header.php'; ?>
      <div class="container">
         <nav class="navbar navbar-expand-lg navbar-dark bg-dark">
          <a class="navbar-brand" href="#">آخرین کتاب ها</a>
        </nav>
         <article class="row">
            <section class="col-lg-8">
            <div class="card-columns">
            <?php 
               $result = mysqli_query($connection,"SELECT * FROM books WHERE cat_id = ");
                while($row = mysqli_fetch_array($result)) :
            ?>
               <div class="card">
                 <img class="card-img-top rounded mx-auto d-block" src="<?php echo $row['image']; ?>" alt="<?php echo $row['title']; ?>" width="199" height="312">
                 <div class="card-body text-right">
                  <h3 class="card-title"><a href="post.php?id=<?php echo $row['id']; ?>"><?php echo $row['title']; ?></a></h3>
                  <p class="card-text"><?php echo mb_substr($row['description'],0,250); echo '...'; ?></p>
                   <a href="book.php?id=<?php echo $row['id']; ?>" class="btn btn-primary">ادامه مطلب</a>
                 </div>
               </div>
            <?php endwhile; ?>
            </div>
         </section>
         <?php include 'includes/sidebar.php'; ?>
         </article>
      </div>
      <div style="width:50px;height:50px;"></div>
<?php include 'includes/footer.php'; ?>
   </body>
</html>
克里斯托弗

您应该在互联网上搜索多对多关系:

一本书可能有零个或多个类别。另一方面,一个类别可能有零个或多个书籍关系。这种关系称为多对多

要存档此目标,您必须添加一个映射表:

table: book   table: book_category   table: category
==========    ====================   ===============
- id          - book_id              - id
- name        - category_id          - name
- author                             - ...
- ...

要查询数据,这里有示例如何查询多对多?. 您应该在互联网上找到许多 php 示例...

备注:OPs 问题在 book 和 post 实体之间切换。我决定使用 book ... ;)

编辑1:

评论中的 OP 问题:如何为提交的书添加行...?

您必须知道相关的书籍和类别 ID。要将一本书连接到一个类别,您只需将 id 添加到连接表中。

INSERT INTO book_category(book_id,category_id) values(40,50);

在这个例子中,id 为 40 的书加入了类别 id 50。

如果您的问题是针对 php 示例,我无法告诉您,因为我不知道您的 DAO 层是如何实现的。但我想这应该是一个新问题。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

获取帖子多个类别

如何在wordpress中仅获取父类别帖子

如何从帖子页面中删除类别类?

如何在帖子/页面中打印自定义帖子类型类别名称

如何在Wordpress中获取帖子名称下的所有帖子类别?

如何在magento的自定义脚本中获取产品的多个类别和子类别

如何在子类别页面中显示Wordpress类别?

如何在 Ionic 应用程序页面中显示来自特定类别的帖子

查询页面标题以获取类别帖子

如何从Genesis Wordpress的存档页面中删除类别帖子

Django:如何过滤和显示页面上类别中的帖子

如何在Django中获取同一类别中的所有帖子

如何在magento中获取当前类别及其子类别?

Blogdown类别页面显示所有帖子,无论类别如何

如何查询类别数组以获取 Laravel 中的帖子?

在帖子页面中添加类别 slug

如何在Wordpress中按子类别搜索帖子

如何在Wordpress中显示特定类别的帖子

如何在 Django 的类别列表中显示帖子列表

如何从类别表中获取 5 个类别并在 Laravel 中获得每个类别的 4 个帖子

在帖子记录中获取类别名称

获取laravel 5.4中的类别帖子

获取JPA,MySQL中类别的帖子

如何在每个类别的加载页面中仅获取 2 个产品

如何在类别页面上的magento中(使用帮助程序)获取新安装的产品属性

如何在Vertica SQL中按多个列及其类别获取主键计数?

获取类别中的自定义帖子和普通帖子

如何在Pandas DataFrame中替换多个类别中的值

如何获取在SQL Server中存在多个类别的产品