Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk melaksanakan fungsi ranking masa nyata yang mudah dalam PHP

Bagaimana untuk melaksanakan fungsi ranking masa nyata yang mudah dalam PHP

Apr 25, 2023 pm 06:26 PM

Dengan perkembangan pesat Internet, kedudukan masa nyata telah menjadi salah satu fungsi yang diperlukan untuk banyak laman web, terutamanya yang mempunyai trafik yang sangat tinggi. Contohnya, senarai masa nyata seperti berita hangat, buku terlaris dan produk popular ialah perkara yang sering dilihat orang di pelbagai tapak web. Dalam artikel ini, kami akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi pemeringkatan masa nyata yang mudah dan meneroka cara meningkatkan prestasinya.

1. Pengenalan fungsi

Senarai masa nyata ialah fungsi yang digunakan untuk memaparkan senarai paling popular atau paling banyak ditonton pada masa ini. Dalam artikel ini, kami akan melaksanakan kedudukan masa nyata berdasarkan kiraan lawatan. Setiap kali pengguna melawat halaman atau melakukan operasi tertentu, kami akan meningkatkan kiraan halaman atau operasi sebanyak 1 dan memaparkannya pada senarai masa nyata mengikut urutan dari tinggi ke rendah.

2. Konfigurasi persekitaran

Untuk merealisasikan fungsi ranking masa nyata, kami memerlukan persekitaran berjalan PHP. Kami boleh menggunakan mana-mana pelayan web yang menyokong PHP untuk mengkonfigurasi persekitaran. Contohnya, Apache, Nginx, dll. Pada masa yang sama, kami juga memerlukan pangkalan data MySQL untuk menyimpan kiraan akses dan maklumat halaman.

3. Langkah-langkah pelaksanaan

1 Cipta pangkalan data

Kita perlu membuat pangkalan data dan menambah jadual untuk menyimpan maklumat halaman dan kiraan akses. Kita boleh menggunakan pernyataan SQL berikut untuk mencipta pangkalan data sampel:

CREATE DATABASE counter;

USE counter;

CREATE TABLE pages (
    id INT(11) NOT NULL AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    PRIMARY KEY (id)
);

CREATE TABLE visits (
    id INT(11) NOT NULL AUTO_INCREMENT,
    page_id INT(11) NOT NULL,
    count INT(11) NOT NULL DEFAULT 1,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    PRIMARY KEY (id),
    FOREIGN KEY (page_id) REFERENCES pages(id) ON DELETE CASCADE ON UPDATE CASCADE
);
Salin selepas log masuk

Kod di atas akan mencipta pangkalan data bernama "counter", mengandungi dua jadual: "halaman" dan "lawatan".

Antaranya, jadual "halaman" digunakan untuk menyimpan maklumat halaman, termasuk ID unik dan nama setiap halaman

Jadual "lawatan" digunakan untuk menyimpan kiraan lawatan setiap halaman, termasuk kiraan lawatan setiap halaman ID unik, ID halaman, kiraan dan masa lawatan.

2. Tulis kod PHP

Seterusnya, kami akan menulis kod PHP untuk melengkapkan fungsi ranking masa nyata. Kami akan menggunakan PDO untuk mengakses pangkalan data.

//Tentukan konfigurasi pangkalan data
$host = 'localhost';
$dbname = 'counter';
$user = 'root' ;
$pass = '';

//Buat sambungan pangkalan data
cuba {

$dbh = new PDO("mysql:host=$host;dbname=$dbname", $user, $pass);
Salin selepas log masuk

} tangkap (PDOException $e) {

echo "Error!: " . $e->getMessage() . "<br/>";
die();</p>
<p>}</p>
<p>//Dapatkan ID dan nama halaman<br>$pageId = $_GET['page_id'];<br>$pageName = $_GET['page_name'];</p>
<p> //Soal ID halaman berdasarkan nama halaman<br>$stmt = $dbh->prepare("SELECT id FROM page WHERE name = ?");<br>$stmt->execute(array($pageName )); <br>$row = $stmt->fetch(PDO::FETCH_ASSOC);<br>jika ($row) {</p>
<pre class="brush:php;toolbar:false">//页面存在,获取页面ID
$pageId = $row['id'];
Salin selepas log masuk

} lain {

//页面不存在,插入新记录并获取新的页面ID
$stmt = $dbh->prepare("INSERT INTO pages (name) VALUES (?)");
$stmt->execute(array($pageName));
$pageId = $dbh->lastInsertId();
Salin selepas log masuk

}

//Kemas kini kiraan lawatan
$stmt = $dbh->prepare("MASUKKAN KE DALAM lawatan (page_id) NILAI (?) PADA DUPLICATE KEY UPDATE count = count + 1");
$stmt->execute(array($pageId));

//Dapatkan senarai masa nyata
$limit = 10; //Dapatkan 10 teratas
$stmt = $dbh-> ;prepare("SELECT pages.name, SUM(visits.count) SEBAGAI kiraan DARIPADA halaman SERTAI lawatan DI pages.id = visits.page_id KUMPULAN MENGIKUT pages.name ORDER OLEH kiraan DESC LIMIT {$limit}") ;
$ stmt->execute();
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);

//Output senarai masa nyata
foreach ( $rows as $row) {

echo "{$row['name']}: {$row['count']}<br>";
Salin selepas log masuk

}

?>

Kod PHP di atas melaksanakan operasi berikut:

1) Pertanyaan nama halaman input dan pertanyaan berdasarkan nama ID Halaman. Jika halaman itu tidak wujud, masukkan rekod baharu dan dapatkan ID halaman baharu.

2) Kemas kini kiraan akses. Jika rekod sudah wujud, nilai kiraan dikemas kini jika rekod tidak wujud, rekod baharu akan dimasukkan.

3) Soal kiraan akses semua halaman berdasarkan jadual kiraan akses dan jadual halaman, dan susunkannya dari tinggi ke rendah mengikut nilai kiraan.

4) Keluarkan 10 halaman pertama dan kiraan akses yang sepadan.

4. Pengoptimuman prestasi

Walaupun kod di atas melaksanakan fungsi kedudukan masa nyata asas, ia mungkin menghadapi masalah prestasi dalam keadaan beban tinggi. Berikut ialah beberapa petua pengoptimuman yang boleh anda gunakan untuk meningkatkan prestasi:

1) Gunakan caching

Anda boleh menggunakan caching untuk mengoptimumkan pertanyaan. Sebagai contoh, hasil pertanyaan boleh dicache dalam memori menggunakan perkhidmatan caching seperti Redis atau Memcached.

2) Gunakan tugas berjadual

Anda boleh menggunakan tugas berjadual untuk menjana kedudukan masa nyata pada selang masa yang tetap dan bukannya menjananya secara dinamik semasa setiap lawatan. Sebagai contoh, kedudukan masa nyata boleh dijana setiap minit atau jam, dan hasilnya boleh dicache dan diambil terus daripada cache apabila diakses.

3) Optimumkan pertanyaan SQL

boleh mengoptimumkan pernyataan pertanyaan SQL, seperti menggunakan indeks, mengelakkan penggunaan subkueri, menggunakan kumpulan sambungan, dsb. Di samping itu, anda juga boleh menggunakan pemecahan pangkalan data dan pemecahan jadual untuk menyuraikan data ke dalam berbilang jadual untuk mengelakkan masalah prestasi yang disebabkan oleh terlalu banyak data dalam satu jadual.

Ringkasnya, senarai masa nyata ialah fungsi penting, tetapi isu prestasi perlu dipertimbangkan semasa melaksanakannya, dan penyelesaian teknikal perlu dipilih secara fleksibel mengikut situasi sebenar.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi ranking masa nyata yang mudah dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Mar 10, 2025 pm 04:21 PM

Artikel ini meneroka pelaksanaan tugas tak segerak dalam PHP untuk meningkatkan respons aplikasi web. Ia memperincikan kaedah seperti beratur mesej, rangka kerja asynchronous (reactphp, swoole), dan proses latar belakang, menekankan amalan terbaik untuk kecekapan

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Mar 10, 2025 pm 04:23 PM

Artikel ini menangani pengoptimuman memori PHP. IT memperincikan teknik seperti menggunakan struktur data yang sesuai, mengelakkan penciptaan objek yang tidak perlu, dan menggunakan algoritma yang cekap. Sumber kebocoran memori biasa (mis., Sambungan yang tidak terkawal, global v

Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Mar 10, 2025 pm 06:16 PM

Artikel ini meneroka strategi untuk kekal semasa dalam ekosistem PHP. Ia menekankan penggunaan saluran rasmi, forum komuniti, persidangan, dan sumbangan sumber terbuka. Penulis menyoroti sumber terbaik untuk mempelajari ciri -ciri baru dan a

See all articles