I have a MySQL table which hen created automatically puts a ISO 8601 timestamp into one of the fields. It does this because I have set the default value thought phpMyAdmin to TIMESTAMP.
When I update the field I want to add another timestamp to another field. Obviously I cant do that using the default option. Is there an SQL command to add a current timestamp to a field? I have had a quick read through the MySQL website but I couldnt find a way to do it…
I also had a look to see if there was a way of generating an ISO8601 timestamp through PHP but I couldnt figure out a way to convert from a PHP/unix timestamp to ISO8601.
Cheers!
MySQL can automatically initialise and/or update a single
TIMESTAMPtype column within every table to the current time onINSERTandUPDATE. As explained in Automatic Initialization and Updating forTIMESTAMP:In your case, because you want separate columns to hold the record’s initialisation and update times, you will need to set one (or both) of those columns explicitly; one can explicitly set a date/time column to the current date/time in SQL using the
NOW()function:One can even use triggers to achieve the automatic behaviour that is not natively provided by MySQL: