A Brief Analysis on the Time Carrying Problem of MySQL

A Brief Analysis on the Time Carrying Problem of MySQL

The default time type (datetime and timestamp) in MySQL has a precision of seconds. If the time value is set with a precision less than a second, it will be rounded off, which may cause the value in the database to be one second more than the original value. In other words, records that originally belonged to today may be recorded tomorrow.

Below is an example that demonstrates how time is rounded. First create a table:

CREATE TABLE test_time (
 time_sec datetime,
 time_millis datetime(3),
 time_micros datetime(6),
 stamp_sec timestamp,
 stamp_millis timestamp(3),
 stamp_micros timestamp(6)
);

Some readers may not know that datetime and timestamp can be defined with precision. The precision value is 0~6, indicating how many decimal places are retained. The default value is 0. Obviously, retaining 3 digits can be regarded as milliseconds precision, and retaining 6 digits can be regarded as microseconds precision.

Then we insert a record:

INSERT INTO test_time
( time_sec, time_millis, time_micros, 
 stamp_sec, stamp_millis, stamp_micros )
VALUES(
 '2019-11-30 12:34:56.987654', 
 '2019-11-30 12:34:56.987654', 
 '2019-11-30 12:34:56.987654',
 '2019-11-30 12:34:56.987654', 
 '2019-11-30 12:34:56.987654', 
 '2019-11-30 12:34:56.987654'
);

Then do another select * from test_time query and you will see the following results:

time_sec |time_millis |time_micros |stamp_sec |stamp_millis |stamp_micros |
---------------------|-----------------------|--------------------------|---------------------|-----------------------|--------------------------|
2019-11-30 12:34:57.0|2019-11-30 12:34:56.988|2019-11-30 12:34:56.987654|2019-11-30 12:34:57.0|2019-11-30 12:34:56.988|2019-11-30 12:34:56.987654|

You can see that the second values ​​of time_sec and stamp_sec in the database are rounded up, and the millisecond values ​​of time_millis and stamp_millis are rounded up.

It can be seen that there are two ways to avoid such errors:

  • Use datetime(6) or timestamp(6) when defining fields;
  • The field is defined without precision, but the millisecond value is truncated before the time is stored in the database.

Related Documents:

MySQL 5.6 Reference: Fractional Seconds in Time Values

Summarize

The above is the full content of this article. I hope that the content of this article will have certain reference learning value for your study or work. Thank you for your support of 123WORDPRESS.COM.

You may also be interested in:
  • Summary of MySQL date data type and time type usage
  • Detailed explanation of TIMESTAMP usage in MySQL
  • MySql query time period method
  • MySQL date and time format conversion implementation statement
  • mysql calculate time difference function
  • FROM_UNIXTIME Format MYSQL timestamp function
  • Mysql date time DATE_FORMAT (date, format)
  • Functions and methods for converting dates and timestamps in MySQL
  • How to write various SQL statements in MySQL to get time data for one day, one week, and one month
  • MySQL timestamp automatic update time sharing

<<:  Example of Vue's implementation of the underlying code for simulating responsive principles

>>:  How to solve the Docker container startup failure

Recommend

MySQL Database Indexes and Transactions

Table of contents 1. Index 1.1 Concept 1.2 Functi...

Detailed tutorial on installing Tomcat9 windows service

1. Preparation 1.1 Download the tomcat compressed...

Source code reveals why Vue2 this can directly obtain data and methods

Table of contents 1. Example: this can directly g...

Use and optimization of MySQL COUNT function

Table of contents What does the COUNT function do...

Implementing circular scrolling list function based on Vue

Note: You need to give the parent container a hei...

Vue implements card flip carousel display

Vue card flip carousel display, while switching d...

Linux C log output code template sample code

Preface This article mainly introduces the releva...

js realizes the function of clicking to switch cards

This article example shares the specific code of ...

Beginners understand MySQL deadlock problem from source code

After many difficult single-step debugging late a...

Solution to the problem that the InnoDB engine is disabled when MySQL is started

Find the problem Today at work, when copying tabl...