php - 在 MySql 中连接表来存储已查看的文章 ID

标签 php mysql sql database joomla3.0

我正在开发一个 Joomla 网站,但对于 MySql 来说我是个新手。我需要能够跟踪用户浏览了多少篇文章,然后能够在页面前端显示浏览过的文章总数(例如,如果用户浏览了 3 篇文章,它应该只回显该值“3”到前端)。

我还希望能够存储文章 ID 和别名,并能够在以后需要时检索该数据。这个想法是,任何特定用户将能够看到他们已经查看了多少文章,甚至可能能够返回并查看这些文章(因为一旦查看它们将不再显示)。

我完全不知道从哪里开始构建表来存储这些数据,以及如何将其连接到当前用户。任何帮助将不胜感激,即使它只是向我指出一个好的教程或资源。

最佳答案

我认为有三种方法:

将所有已查看的文章 ID 存储在用户表的新列中
您可以向用户表添加一列来存储已查看的文章。您可以将文章 ID 存储为逗号分隔值。每次查看新文章时,您都可以附加新的文章 ID。在前端,您可以使用 select 语句检索该字符串并解析它以获取各个 ID。

此方法对于 Joomla 等 CMS 可能不实用,因为向系统表添加列会带来麻烦。

每个用户一行的新表
您创建一个新的两列表,一列包含用户 ID,另一列包含已查看文章的逗号分隔列表。现有用户表和新表之间将存在 1-0 关系。

简单的联接将允许您检索与关联用户关联的已查看文章。

每个用户/文章组合一行的新表
您创建一个新的两列历史记录表,其中存储用户和单个已查看的文章 ID。如果用户查看了十篇文章,则会有十行。

检索给定用户查看的文章需要一些工作,因为您必须提取该用户的所有行并迭代它们。

编辑 - 示例代码:

<?php
$config['db'] = array (
    'host' => '',
    'username' => '',
    'password' => '',
    'dbname'    => ''
);

$db = new PDO('mysql:host=' . $config['db']['host'] . ';dbname='.$config['db']['dbname'],$config['db']['username'],$config['db']['password']);

$query = $db->query("SELECT user_id, article_id FROM viewed_articles WHERE user_id = 1234");

$rows = $query->fetchAll(PDO::FETCH_ASSOC);

echo '<pre>',print_r($rows,true),'</pre>';

?>

您可以将 MySQL 数据库和凭据放入 $config 数组中。

关于php - 在 MySql 中连接表来存储已查看的文章 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24030206/

相关文章:

php - 无法打开流 : Permission denied

php - 通过 CSV 复制记录更新数据库

mysql - 外键限制可以带来安全利益和/或风险吗?

sql - 雅典娜 : Query exhausted resources at scale factor

c# - 在表中,列数据类型为 varchar,使用 linq to sql 仅检索列中数字/数字的值

php - mysql查询的意外输出

php - CodeIgniter 更新查询不起作用

PHP 数据对象从表中获取字段名称

MySQL 查询 - 如果单元格为空,则

java - 通过基于三个过滤器连接条件创建一个简单的 SQL 查询 - Java 和 MySQL