」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 我該如何使用 PHP 和 MySQL 解決具有挑戰性的後端問題

我該如何使用 PHP 和 MySQL 解決具有挑戰性的後端問題

發佈於2024-07-31
瀏覽:239

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 的好處中受益更多。

版本聲明 本文轉載於:https://dev.to/cyberking99/solving-a-challenging-backend-problem-with-php-h0l?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何實時捕獲和流媒體以進行聊天機器人命令執行?
    如何實時捕獲和流媒體以進行聊天機器人命令執行?
    在開發能夠執行命令的chatbots的領域中,實時從命令執行實時捕獲Stdout,一個常見的需求是能夠檢索和顯示標準輸出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    程式設計 發佈於2025-03-25
  • 為什麼使用Firefox後退按鈕時JavaScript執行停止?
    為什麼使用Firefox後退按鈕時JavaScript執行停止?
    導航歷史記錄問題:JavaScript使用Firefox Back Back 此行為是由瀏覽器緩存JavaScript資源引起的。要解決此問題並確保在後續頁面訪問中執行腳本,Firefox用戶應設置一個空功能。 警報'); }; alert('inline Alert')...
    程式設計 發佈於2025-03-25
  • 如何正確使用與PDO參數的查詢一樣?
    如何正確使用與PDO參數的查詢一樣?
    在pdo 中使用類似QUERIES在PDO中的Queries時,您可能會遇到類似疑問中描述的問題:此查詢也可能不會返回結果,即使$ var1和$ var2包含有效的搜索詞。錯誤在於不正確包含%符號。 通過將變量包含在$ params數組中的%符號中,您確保將%字符正確替換到查詢中。沒有此修改,PD...
    程式設計 發佈於2025-03-25
  • 編譯器可以在C ++中優化“新呼叫”嗎?
    編譯器可以在C ++中優化“新呼叫”嗎?
    編譯器可以消除堆內存分配? 在堆中進行的。編譯器可以優化代碼,包括刪除不必要的語句。編譯器能否消除使用新的? 優化的有效性 c 14標準 :clang還對非截止的新運營商的呼叫也優化了新運營商。全球操作員在不同的翻譯單元中的新實現可能會影響編譯器優化與堆分配相關的有效性。 的功能優化堆積問題是...
    程式設計 發佈於2025-03-25
  • 對象擬合:IE和Edge中的封面失敗,如何修復?
    對象擬合:IE和Edge中的封面失敗,如何修復?
    To resolve this issue, we employ a clever CSS solution that solves the problem:position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%)...
    程式設計 發佈於2025-03-25
  • 在Ubuntu/linux上安裝mysql-python時,如何修復\“ mysql_config \”錯誤?
    在Ubuntu/linux上安裝mysql-python時,如何修復\“ mysql_config \”錯誤?
    mysql-python安裝錯誤:“ mysql_config找不到”“ 由於缺少MySQL開發庫而出現此錯誤。解決此問題,建議在Ubuntu上使用該分發的存儲庫。使用以下命令安裝Python-MysqldB: sudo apt-get安裝python-mysqldb sudo pip in...
    程式設計 發佈於2025-03-25
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP將...
    程式設計 發佈於2025-03-25
  • 如何簡化PHP中的JSON解析以獲取多維陣列?
    如何簡化PHP中的JSON解析以獲取多維陣列?
    php 試圖在PHP中解析JSON數據的JSON可能具有挑戰性,尤其是在處理多維數組時。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    程式設計 發佈於2025-03-25
  • 哪種在JavaScript中聲明多個變量的方法更可維護?
    哪種在JavaScript中聲明多個變量的方法更可維護?
    在JavaScript中聲明多個變量:探索兩個方法在JavaScript中,開發人員經常遇到需要聲明多個變量的需要。對此的兩種常見方法是:在單獨的行上聲明每個變量: 當涉及性能時,這兩種方法本質上都是等效的。但是,可維護性可能會有所不同。 第一個方法被認為更易於維護。每個聲明都是其自己的語句,使...
    程式設計 發佈於2025-03-25
  • 引用還是不引用:字體姓氏何時應包含在CSS中的報價中?
    引用還是不引用:字體姓氏何時應包含在CSS中的報價中?
    解決風格困境:是否應該用CSS中的引號? 技術基礎,可以指定字體家族名稱或不帶引用。當未引用時,名稱應該是一系列標識符。但是,標識符不能包含空格或某些標點符號。要包含這些字符,必須逃脫它們或應引用名稱。 實際含義在實踐中,從包含空間的字體姓名中刪除引號並不是在諸如Safari和Firefox之類的...
    程式設計 發佈於2025-03-25
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-03-25
  • 如何在SQL中有效地轉置列和行?
    如何在SQL中有效地轉置列和行?
    SQL行列轉換的簡易方法 雖然SQL的PIVOT函數看似適合進行行列轉換,但其複雜性可能會令人卻步。如果您希望以更簡便的方式實現此目標,請考慮以下替代方法: 使用UNION ALL、聚合函數和CASE語句 此方法使用UNION ALL將數據展開,然後使用聚合函數和CASE語句進行透視: SELEC...
    程式設計 發佈於2025-03-25
  • Python讀取CSV文件UnicodeDecodeError終極解決方法
    Python讀取CSV文件UnicodeDecodeError終極解決方法
    在試圖使用已內置的CSV模塊讀取Python中時,CSV文件中的Unicode Decode Decode Decode Decode decode Error讀取,您可能會遇到錯誤的錯誤:無法解碼字節 在位置2-3中:截斷\ uxxxxxxxx逃脫當CSV文件包含特殊字符或Unicode的路徑逃...
    程式設計 發佈於2025-03-25
  • 為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    查詢模式實現缺失:解決“無法找到”錯誤在銀光應用程序中,嘗試使用LINQ建立錯誤的數據庫連接的嘗試,無法找到以查詢模式的實現。 ”當省略LINQ名稱空間或查詢類型缺少IEnumerable 實現時,通常會發生此錯誤。 解決問題來驗證該類型的質量是至關重要的。在此特定實例中,tblpersoon可能...
    程式設計 發佈於2025-03-25
  • 您如何在Laravel Blade模板中定義變量?
    您如何在Laravel Blade模板中定義變量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配變量對於存儲以後使用的數據至關重要。在使用“ {{}}”分配變量的同時,它可能並不總是最優雅的解決方案。 幸運的是,Blade通過@php Directive提供了更優雅的方法: $ old_section =...
    程式設計 發佈於2025-03-25

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3