Cause Analysis of negative MySQL execution time

Source: Internet
Author: User

CopyCodeThe Code is as follows: <? PHP
List ($ USEC, $ Sec) = explode ('', microtime ());
$ Timer = (float) $ USEC + (float) $ sec;
Mysql_query ($ query, $ active_db );
List ($ USEC, $ Sec) = explode ('', microtime ());
$ Stop = (float) $ USEC + (float) $ sec;
$ Diff = $ stop-$ timer;
?>

$ Stop and $ timer are converted floating point numbers. In most cases, the results obtained by ECHO $ stop and echo $ timer are the same with the naked eye, however, they are stored in different computers, so the result is not 0 or negative.

The PHP manual prompts:

Floating Point precision:
Obviously, a simple decimal score is like 0.1 or 0.7. It cannot be converted to an internal binary format without losing a little precision. This will lead to chaotic results: for example, floor (0.1 + 0.7) * 10) usually returns 7 instead of 8 in expectation, because the internal representation of the result is similar to 7. 9999999999 ....

This is related to the fact that it is impossible to accurately express certain decimal scores with limited digits. For example, decimal 1/3 is changed to 0.3333333 ....

Therefore, never believe that the result of a floating point number is accurate to the last digit, or compare whether the two floating points are equal. If higher precision is required, use any precision mathematical function or GMP function.

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.