


The efficiency of reading and writing files and reading and writing databases in PHP_PHP Tutorial
This article will introduce to you a comparison of the efficiency of reading and writing files and reading and writing databases in PHP. Friends who need to know more can refer to it.
The test program is as follows:
//Explanation 1: Since the read database statement calls the simple packet function twice, the read file is also changed to be called twice consecutively. The database record ID is 1 in the first One, and unique index.
The code is as follows | Copy code | ||||
{ $content = file_get_contents($filename); return $content; }function fnGetContent($filename) { $content = fnGet($filename); return $content; } $times=100000; echo 'Database query results: '; //-------------------------------- $begin =fnGetMicroTime(); for($i=0;$i<$times;$i++) { $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); $row=$dbcon->mydb_fetch_row($res); $content=$row[0]; } echo ' fetch_row '.$times.' times: '.(fnGetMicroTime()-$begin).'seconds '; //- --------------------------------$begin=fnGetMicroTime(); for ($i=0;$i<$times;$i++) { $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); $row=$dbcon->mydb_fetch_array($res); $content=$row['log_Content']; } echo 'fetch_array '.$times.' times Time: '.(fnGetMicroTime()-$begin).'Seconds '; //--------- --------------------------$begin=fnGetMicroTime(); for($i=0;$i< ;$times;$i++) { $res=$dbcon->mydb_query("SELECT log_Content FROM blog WHERE log_ID='1'"); $row=$dbcon- >mydb_fetch_object($res); $content=$row->log_Content; } echo 'fetch_object '.$times.' times: '.(fnGetMicroTime()-$begin).'seconds '; //------------------ ---------------$dbcon->mydb_free_results(); $dbcon->mydb_disconnect();fnWriteCache ('test.txt',$content);echo 'Directly read the file test results: ';//--------- -------------------------- $begin=fnGetMicroTime(); for($i=0;$i<$ times;$i++) { $content = fnGetContent('test.txt'); } echo 'file_get_contents read directly'.$times.' times: < ;font color=red>'.(fnGetMicroTime()-$begin).'seconds '; //------------ ---------------------$begin=fnGetMicroTime(); for($i=0;$i<$times ;$i++) { $fname = 'test.txt'; if(file_exists($fname)) { $fp=fopen($fname , "r");//flock($fp,LOCK_EX); fp); } $content = fnGetContent('test.txt'); } echo 'fopen reads directly '.$times.' times: '.(fnGetMicroTime()-$begin).'seconds '; |
Query results for 4K size data:
fetch_row 100000 times: 16.737720012665 seconds
fetch_array 100000 times: 16.661195993423 seconds
fetch_object 100000 times Time: 16.775065898895 seconds
Direct file reading test results:
file_get_contents direct reading 100000 times time: 5.4631857872009 seconds
fopen direct reading 100000 times time: 11.463611125946 seconds
Plastic ID query Result:
fetch_row 100000 times time: 12.812072038651 seconds
fetch_array 100000 times time: 12.667390108109 seconds
fetch_object 100000 times time: 12.9880990 98206 seconds
Read the file directly Test results:
File_get_contents read directly 100000 times time: 5.6616430282593 seconds
fopen read directly 100000 times time: 11.542816877365 seconds
Test conclusion:
1. Reading files directly is more efficient than database query, and the connection and disconnection time is not included in the article.
2. The larger the content read at one time, the more obvious the advantage of reading files directly (the time to read files increases slightly, which is related to the continuity of file storage and cluster size). This result It is exactly the opposite of what Tianyuan expected, indicating that MYSQL may have additional operations for reading larger files (the time increased by nearly 30% twice). If it is just a simple assignment conversion, the difference should be small.
3. Writing files and INSERT can be inferred with almost no testing, and the database efficiency will only get worse.
4. If a small configuration file does not need to use database features, it is more suitable to be stored in a separate file for access. There is no need to create a separate data table or record. Large files such as pictures, music, etc. use files. Storage is more convenient, and it is more reasonable to only put index information such as paths or thumbnails in the database.
5. If you only read files on PHP, file_get_contents is more efficient than fopen and fclose. Excluding the time required to determine the existence of this function, it will take about 3 seconds less.
6. fetch_row and fetch_object should be converted from fetch_array. Tianyuan has not seen the source code of PHP. From the execution alone, it can be seen that fetch_array is more efficient. This seems to be contrary to what is said on the Internet.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
