Home >Backend Development >PHP Tutorial >Example explanation of PHP timestamp_PHP tutorial
Everyone We will definitely encounter this situation: Bank A and Bank B open your account almost at the same time and see the original deposit of 1,000 yuan in your account, and then the two banks Everyone wants to add a 500 yuan deposit to your account. Then, Bank A changes the amount from 1,000 yuan to 1,500 yuan, and at the same time, Bank B also changes the amount from 1,000 yuan to 1,500 yuan. That's bad! In the end, you end up with only 1,500 yuan in your bank account instead of the 2,000 yuan you should have, which is equivalent to a loss of 500 yuan! This is where modifications without locking the data cause serious problems. However, we can solve this problem neatly through PHP timestamps.
Let’s look at the idea:
Create a PHP timestamp field timestamp in the bank account table and set it to the text type varchar.
When bank A reads the deposit field in the account table, it also reads the timestamp field, such as 123456.
When Bank A modifies the deposit value and performs a save operation, compare the previously read timestamp 123456 with the PHP timestamp in the current table. If they are consistent, the save is allowed and a new time is generated. A stamp such as 456789 replaces the original timestamp 123456 in the table.
What benefits will this bring?
Let’s look at the situation at the beginning: Bank A and Bank B opened your account almost at the same time and saw the original deposit of 1,000 yuan in your account. At the same time, the two banks read the timestamp 123456 at the same time. There will be a difference next. When Bank A changes 1,000 yuan to 1,500 yuan and saves the deposit, the system will compare whether the previous timestamp 123456 is consistent with the timestamp in the table at the time of deposit. Obviously, it should be consistent now, so it is allowed Save and generate a new timestamp 456789 to replace the old timestamp 123456. Next, Bank B also changed 1,000 yuan to 1,500 yuan and saved it. The system compared the previous timestamp 123456 to see if it was consistent with the timestamp in the table when saving, and found that the previous timestamp 123456 was different from the current timestamp 456789. , the system refuses to save and requires refreshing the data. Then after the data is refreshed, the 1,000 yuan has become 1,500 yuan because Bank A previously deposited 500 yuan. Then Bank B will change the 1,500 yuan to 2,000 yuan and save again. The system allows it. In this way, we avoid errors caused by repeatedly modifying data!
It's a bit like a tongue twister, I hope everyone understands what I mean~
Finally, let's look at some operation codes of PHP timestamp.
Get timestamp
<ol class="dp-xml"><li class="alt"> <span><strong><font color="#006699"><span class="tag"><?</SPAN><SPAN class=tag-name>php</SPAN></FONT></STRONG><SPAN> </SPAN></SPAN><LI class=""><SPAN>$</SPAN><SPAN class=attribute-value><FONT color=#0000ff>time</FONT></SPAN><SPAN class=attribute><FONT color=#ff0000>timestamp</FONT></SPAN><SPAN>=time(); </SPAN></SPAN><LI class=alt><SPAN>echo $timestamp; </SPAN><LI class=""><SPAN></SPAN><SPAN class=tag><STRONG><FONT color=#006699>?></span></font></strong></span><span> </span> </li></ol>
SQL statement to update timestamp:
update table name set field name=$timestamp where condition=value;