如何在类别页面中获取多个类别帖子?
How to get multiple category posts in category page?
我正在开发自定义 CMS。我的问题是我有一个 post 有两个类别 'tutorial' 和 'language'。我想把它显示为类别页面中的一个项目。
这是我的book_categorytable
这是我的书 table。
问题一:多分类的图书如何存入数据库?我应该将类别 ID 作为字符串值存储在数据库中吗?
问题2:如何查询post多分类?
这是我的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 用于显示特定类别 posts。
<?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 添加一个字段 category_id
,但是当一本书可以有多个类别并且您不知道有多少时。您可以通过创建第二个 table 来实现最佳效果,该 table 连接多个类别的多行。
创建一个 table books_category
,其中包含 id
、books_id
、books_category_id
等字段。还要在 books_id
、books_category_id
上建立索引以便快速搜索。
对于您的查询,您应该使用 INNER JOIN
。
SELECT * FROM `books` INNER JOIN `books_category` ON `books_category`.`books_id` = `books`.`id` WHERE `books_category`.`books_category_id` = 5
您应该在互联网上搜索多对多 关系:
一本书可以有零个或多个类别。另一方面,一个类别可能有零个或多个书籍关系。这种关系称为多对多。
要存档此目标,您必须添加一个映射 table:
table: book table: book_category table: category
========== ==================== ===============
- id - book_id - id
- name - category_id - name
- author - ...
- ...
要查询数据,这里有示例 how to query many-to-many?。
你应该在互联网上找到很多 php 的例子...
备注:OP 问题在书籍和 post 实体之间切换。我决定使用书...;)
编辑 1:
OPs 评论中的问题:如何为提交的书添加行...?
您必须知道相关的图书和类别 ID。要将一本书连接到一个目录,您只需将 id 添加到连接 table.
INSERT INTO book_category(book_id,category_id) values(40,50);
在此示例中,id 为 40 的图书已加入类别 id 50。
如果您的问题针对的是 php 示例,我无法告诉您,因为我不知道您的 DAO 层是如何实现的。但我想这应该是一个新问题。
我正在开发自定义 CMS。我的问题是我有一个 post 有两个类别 'tutorial' 和 'language'。我想把它显示为类别页面中的一个项目。
这是我的book_categorytable
这是我的书 table。
问题一:多分类的图书如何存入数据库?我应该将类别 ID 作为字符串值存储在数据库中吗?
问题2:如何查询post多分类?
这是我的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 用于显示特定类别 posts。
<?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 添加一个字段 category_id
,但是当一本书可以有多个类别并且您不知道有多少时。您可以通过创建第二个 table 来实现最佳效果,该 table 连接多个类别的多行。
创建一个 table books_category
,其中包含 id
、books_id
、books_category_id
等字段。还要在 books_id
、books_category_id
上建立索引以便快速搜索。
对于您的查询,您应该使用 INNER JOIN
。
SELECT * FROM `books` INNER JOIN `books_category` ON `books_category`.`books_id` = `books`.`id` WHERE `books_category`.`books_category_id` = 5
您应该在互联网上搜索多对多 关系:
一本书可以有零个或多个类别。另一方面,一个类别可能有零个或多个书籍关系。这种关系称为多对多。
要存档此目标,您必须添加一个映射 table:
table: book table: book_category table: category
========== ==================== ===============
- id - book_id - id
- name - category_id - name
- author - ...
- ...
要查询数据,这里有示例 how to query many-to-many?。 你应该在互联网上找到很多 php 的例子...
备注:OP 问题在书籍和 post 实体之间切换。我决定使用书...;)
编辑 1:
OPs 评论中的问题:如何为提交的书添加行...?
您必须知道相关的图书和类别 ID。要将一本书连接到一个目录,您只需将 id 添加到连接 table.
INSERT INTO book_category(book_id,category_id) values(40,50);
在此示例中,id 为 40 的图书已加入类别 id 50。
如果您的问题针对的是 php 示例,我无法告诉您,因为我不知道您的 DAO 层是如何实现的。但我想这应该是一个新问题。