Table of Contents
Reply content:
Home Backend Development PHP Tutorial mysql - php database cache design

mysql - php database cache design

Jul 06, 2016 pm 01:54 PM
mysql php php framework

For example, if you want to display the total number of views of all sub-items under a category, it is impossible to count it once a user visits it. It is too resource-intensive. Please give me some advice on how to count it again after a period of time

Reply content:

For example, if you want to display the total number of views of all sub-items under a category, it is impossible to count it once a user visits it. It is too resource-intensive. Please give me some advice on how to count it again after a period of time

$redis = new redis();
$pv = "select pv from views where id={$id}";//第一次的pv值
$num = 100;// 累计100更新数据库
$incrPv = $redis->incr('pv:'.$id);
if ($incrPv % $num === 0) {
    $sql = "update views set pv=pv+{$num} where id = {$id}";
} else if ($incrPv == 1) {
   $incrPv = $pv + 1;
   $redis->set('pv:'.$id, $incrPv);
}
Copy after login

Write a timing script to count old data
To count the number of views, you can use redis for caching

Real-time statistics are written to redis or other nosql databases, and crontab calculates and clears the nosql regularly
Execute PHP code online

It’s very simple, just set up the cache where you set the view count of the sub-items under the corresponding category.

For example, let me give you this example:

<code>// 这个方法是你说的统计一个父类下对应所有子类的浏览量的综合,`$time`是设置的缓存时间
function getCategoryNum($categoryId, $time=3600){
    // 根据父类id统计所有子类的浏览量
}

// 这个是每次访问时统计到你数据库或者缓存的地方的方法。这个方法是不用设置缓存的,因为每次都要做统计
function getViewsNum(){
    // 用户访问浏览量+1操作
}</code>
Copy after login

The cache time is set through the above getCategoryNum() method. The database will not be requested during the cache time. Only when the time is up will the database be requested to obtain the latest statistics. This is based on the time you set. .

How to set up cache that you should have in your project! If you want to do scheduled tasks, I think it's a bit wasteful. Of course, I am not sure of your specific business needs. Everything is subject to your business needs. Hope it helps you

If you do not plan to use other caching technologies, you can use mysql for caching. The cache structure is roughly Key, Value, and the last update time. If it exceeds this time, it will be updated. It should be noted that it needs to be considered when writing. Whether to verify the consistency of the written version

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1655
14
PHP Tutorial
1252
29
C# Tutorial
1226
24
The Continued Use of PHP: Reasons for Its Endurance The Continued Use of PHP: Reasons for Its Endurance Apr 19, 2025 am 12:23 AM

What’s still popular is the ease of use, flexibility and a strong ecosystem. 1) Ease of use and simple syntax make it the first choice for beginners. 2) Closely integrated with web development, excellent interaction with HTTP requests and database. 3) The huge ecosystem provides a wealth of tools and libraries. 4) Active community and open source nature adapts them to new needs and technology trends.

MySQL and phpMyAdmin: Core Features and Functions MySQL and phpMyAdmin: Core Features and Functions Apr 22, 2025 am 12:12 AM

MySQL and phpMyAdmin are powerful database management tools. 1) MySQL is used to create databases and tables, and to execute DML and SQL queries. 2) phpMyAdmin provides an intuitive interface for database management, table structure management, data operations and user permission management.

MySQL vs. Other Programming Languages: A Comparison MySQL vs. Other Programming Languages: A Comparison Apr 19, 2025 am 12:22 AM

Compared with other programming languages, MySQL is mainly used to store and manage data, while other languages ​​such as Python, Java, and C are used for logical processing and application development. MySQL is known for its high performance, scalability and cross-platform support, suitable for data management needs, while other languages ​​have advantages in their respective fields such as data analytics, enterprise applications, and system programming.

The Compatibility of IIS and PHP: A Deep Dive The Compatibility of IIS and PHP: A Deep Dive Apr 22, 2025 am 12:01 AM

IIS and PHP are compatible and are implemented through FastCGI. 1.IIS forwards the .php file request to the FastCGI module through the configuration file. 2. The FastCGI module starts the PHP process to process requests to improve performance and stability. 3. In actual applications, you need to pay attention to configuration details, error debugging and performance optimization.

How to safely store JavaScript objects containing functions and regular expressions to a database and restore? How to safely store JavaScript objects containing functions and regular expressions to a database and restore? Apr 19, 2025 pm 11:09 PM

Safely handle functions and regular expressions in JSON In front-end development, JavaScript is often required...

Explain the purpose of foreign keys in MySQL. Explain the purpose of foreign keys in MySQL. Apr 25, 2025 am 12:17 AM

In MySQL, the function of foreign keys is to establish the relationship between tables and ensure the consistency and integrity of the data. Foreign keys maintain the effectiveness of data through reference integrity checks and cascading operations. Pay attention to performance optimization and avoid common errors when using them.

SQL vs. MySQL: Clarifying the Relationship Between the Two SQL vs. MySQL: Clarifying the Relationship Between the Two Apr 24, 2025 am 12:02 AM

SQL is a standard language for managing relational databases, while MySQL is a database management system that uses SQL. SQL defines ways to interact with a database, including CRUD operations, while MySQL implements the SQL standard and provides additional features such as stored procedures and triggers.

Using Laravel: Streamlining Web Development with PHP Using Laravel: Streamlining Web Development with PHP Apr 19, 2025 am 12:18 AM

Laravel optimizes the web development process including: 1. Use the routing system to manage the URL structure; 2. Use the Blade template engine to simplify view development; 3. Handle time-consuming tasks through queues; 4. Use EloquentORM to simplify database operations; 5. Follow best practices to improve code quality and maintainability.

See all articles