为网站或博客中的文章设置阅读量可提供其受欢迎程度的见解。在 php 中实现此功能涉及:创建一个用于存储阅读量的数据库表。连接到数据库并获取要更新阅读量文章的 id。获取当前阅读量,将其加 1,并使用 sql 语句更新数据库。显示文章的阅读量,将其打印到页面上。
如何在 PHP 中设置文章阅读量
为网站或博客中的文章设置阅读量可提供有关文章受欢迎程度的见解。在 PHP 中,可以使用数据库轻松实现此操作。
步骤 1:创建数据库表
首先,创建用于存储文章阅读量的数据库表。该表应包含以下列:
立即学习“PHP免费学习笔记(深入)”;
CREATE TABLE article_views ( id INT NOT NULL AUTO_INCREMENT, article_id INT NOT NULL, view_count INT NOT NULL DEFAULT 0, PRIMARY KEY (id), UNIQUE INDEX article_id_unique (article_id) );
登录后复制
- id:主键列。
- article_id:与文章关联的外键列。
- view_count:存储文章阅读量的列。
步骤 2:连接到数据库
使用 mysqli 或 PDO 等 PHP 数据库扩展连接到数据库。
步骤 3:更新阅读量
以下 PHP 代码演示了如何更新特定文章的阅读量:
<?php // 连接到数据库 $conn = new mysqli("host", "username", "password", "database"); // 获取文章 ID $articleId = $_GET['article_id']; // 检查文章是否存在 $sql = "SELECT * FROM articles WHERE id=?"; $stmt = $conn->prepare($sql); $stmt->bind_param('i', $articleId); $stmt->execute(); $result = $stmt->get_result(); if ($result->num_rows == 0) { // 文章不存在 echo "文章不存在"; exit; } // 获取当前阅读量 $sql = "SELECT view_count FROM article_views WHERE article_id=?"; $stmt = $conn->prepare($sql); $stmt->bind_param('i', $articleId); $stmt->execute(); $result = $stmt->get_result(); $row = $result->fetch_assoc(); $viewCount = $row['view_count']; // 更新阅读量 $viewCount++; $sql = "UPDATE article_views SET view_count=? WHERE article_id=?"; $stmt = $conn->prepare($sql); $stmt->bind_param('ii', $viewCount, $articleId); $stmt->execute(); // 关闭连接 $conn->close(); ?>
登录后复制
此代码从 URL 参数中获取文章 ID。然后,它使用 SQL 语句检查文章是否存在,并获取当前阅读量。最后,它将阅读量加 1 并使用另一个 SQL 语句更新数据库。
步骤 4:显示阅读量
要在网站上显示文章的阅读量,可以使用以下代码:
<?php // 连接到数据库 $conn = new mysqli("host", "username", "password", "database"); // 获取文章 ID $articleId = $_GET['article_id']; // 获取阅读量 $sql = "SELECT view_count FROM article_views WHERE article_id=?"; $stmt = $conn->prepare($sql); $stmt->bind_param('i', $articleId); $stmt->execute(); $result = $stmt->get_result(); $row = $result->fetch_assoc(); $viewCount = $row['view_count']; // 关闭连接 $conn->close(); // 显示阅读量 echo "阅读量:{$viewCount}"; ?>
登录后复制
将阅读量打印到页面上。
以上就是php中如何设置文章阅读量的详细内容,更多请关注php中文网其它相关文章!