gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 00:11:15 26 4
gpt4 key购买 nike

我正在开发一个 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com