首页 > 后端开发 > php教程 > 我如何使用 PHP 和 MySQL 解决具有挑战性的后端问题

我如何使用 PHP 和 MySQL 解决具有挑战性的后端问题

王林
发布: 2024-07-17 21:13:21
原创
1157 人浏览过

How I Solved a Challenging Backend Problem with PHP & MySQL

大家好,我已经有一段时间没有写博客文章了;好吧,我在这里写的是我遇到的最具挑战性的问题之一,以及我如何解决它的概述。

作为后端开发人员,挑战尤其是那些会让你兴奋的挑战是无法逃避的。最近,在使用 PHP 和 MySQL 开发广告网络时,我遇到了一个与基于特定标准为发布商优化每千次成本 (CPM) 相关的复杂问题。这个问题考验了我的技术能力,并提供了宝贵的学习经验。在这篇文章中,我将向您介绍我如何逐步解决这个问题,重点介绍所面临的挑战和实施的解决方案。如果我能得到有关如何有效实施或更好的方法的建议,我将很高兴。

问题

任务是根据以下标准调整发布商的每千次展示费用:

  1. 如果过去 10 分钟内有来自 10 个不同 IP 地址的点击,则增加 5%。
  2. 如果过去 10 分钟内来自同一 IP 地址的点击 5 次,则减少 8%。
  3. 如果来自同一国家/地区连续 10 次点击,则增加 2%。

解决方案之旅

第 1 步:了解要求

在开始实施之前,我需要清楚地了解需求。我与利益相关者进行了讨论,以确认调整 CPM 的标准和期望的行为。这第一步对于有效规划解决方案至关重要。

第 2 步:设置数据库

我已经创建了数据库和表,而且该项目已经上线,所以我只需要添加条件即可。我确保数据库和表已设置为存储和容纳点击跟踪所需的信息。表架构包含用于存储点击时间戳、IP 地址和国家/地区代码的字段(还有其他字段/列,我不会包含这些字段/列,因为它们对于本文的原因并不重要)。

第 3 步:捕获点击数据

接下来,我实现了一个函数,用于在用户点击广告时获取并保存 IP 地址和国家/地区代码。此数据存储在点击表中。

第 4 步:实施标准检查

捕获数据后,下一步是实施逻辑来检查标准并相应地调整 CPM。

  1. 检查唯一的 IP 地址 我使用 COUNT 函数和 DISTINCT 关键字计算过去 10 分钟内的唯一 IP 地址,该关键字计算组中每一行的表达式并返回唯一非空值的数量。
/** 
 * Get the count of unique IP addresses in the last 10 minutes
 */
$stmt = $pdo->prepare("
    SELECT COUNT(DISTINCT ip_address) AS unique_ips
    FROM clicks
    WHERE date_time >= NOW() - INTERVAL 10 MINUTE
");
$stmt->execute();
$unique_ips = $stmt->fetchColumn();

if ($unique_ips >= 10) {
    $cpm *= 1.05;
} else {
    /**
     * Here, I check for clicks from the same IP address
     * This is in the second condition
     * ...
     **/
}
登录后复制
  1. 检查重复的 IP 地址 然后,我使用 SQL COUNT 函数检查过去 10 分钟内重复或不唯一的 IP 地址。
/** 
 * Checking non-unique (repeated) IP addresses in the last 10 minutes
 * If the condition is true, decrease the CPM by 8%
 */
$stmt = $pdo->prepare("
    SELECT ip_address, COUNT(*) AS click_count
    FROM clicks
    WHERE timestamp >= NOW() - INTERVAL 10 MINUTE
    GROUP BY ip_address
    HAVING click_count >= 5
");
$stmt->execute();
$repeated_ips = $stmt->fetchAll();

if (count($repeated_ips) > 0) {
    $cpm *= 0.92;
} else {
    /**
     * Here, I check for consecutive clicks from the same country
     * This is in the third condition
     * ...
     **/
}
登录后复制
  1. 检查来自同一国家/地区的连续点击 在这里,我应用第三个标准,即检查来自同一国家/地区的连续点击。
/** 
 * Checking clicks from the same country consecutively
 * If the condition is true, increase the CPM by 2%
 */
$stmt = $pdo->prepare("
    SELECT country_code
    FROM clicks
    ORDER BY timestamp DESC
    LIMIT 10
");
$stmt->execute();
$last_ten_clicks = $stmt->fetchAll(PDO::FETCH_COLUMN);

if (count(array_unique($last_ten_clicks)) === 1) {
    $cpm *= 1.02;
}
登录后复制

第 5 步:更新每千次展示费用

对于这一部分,我更新发布商的 CPM 并用它来计算他针对该特定点击的收入。

结果

通过实施此解决方案,广告网络现在可以根据用户的点击数据动态调整 CPM。这确保了发布商拥有公平且优化的收入模式,从而提高了广告网络的整体效率。

关于我以及为什么选择 HNG 实习?

我是 Kingsley Gbutemu Kefas,一位热衷于构建可扩展且高效系统的后端开发人员。我是一个问题解决者,我喜欢学习新事物和做事的方法。作为一名开发人员,我的动力来自解决挑战,尤其是那些让我批判性思考的复杂挑战。我知道 HNG 实习对我来说是一个通过从事实际项目并向行业专家学习来成长为开发人员的机会。我很高兴能够开始 HNG 实习之旅并为技术社区做出贡献。我相信这次旅程将提高我的技能并为有影响力的项目做出贡献,并且我确信我将从 HNG Premium 的好处中受益更多。

以上是我如何使用 PHP 和 MySQL 解决具有挑战性的后端问题的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板