I have a table in my database called “usercardsetplaycounts” that has a column called “updatedAt” that I want to get updated with a fresh timestamp every time a row is edited.
data:image/s3,"s3://crabby-images/a3be9/a3be98c93ac1118e2808e47866e64c6c68249988" alt=""
When I originally set this column up, I set the default to CURRENT_TIMESTAMP
. Here is what it looks like in phyMyAdmin:
data:image/s3,"s3://crabby-images/2bc27/2bc274a2e3e38d222aefe55a85518ce63af89008" alt=""
The updatedAt date is set to the timestamp of when the table was created, and does not change when rows are edited.
To fix this, I went to the Structure view in phpMyAdmin and clicked the “Change” link in the Action column.
data:image/s3,"s3://crabby-images/49841/49841a50895553d7c3372c5b2f71cf99fe60f684" alt=""
Which then loads the details for this column:
data:image/s3,"s3://crabby-images/0b32b/0b32b1f3404d9574c1f998b69d065404d48f53b5" alt=""
I then changed the Type from DATETIME
to TIMESTAMP
.
data:image/s3,"s3://crabby-images/c26bd/c26bdd6bbe8410a922cd380a411a4df45515b02d" alt=""
And I changed the Attributes from blank to “on update CURRENT_TIMESTAMP”. For example:
data:image/s3,"s3://crabby-images/4eb89/4eb890864ffc522fe74c6cc5185440a3781c239c" alt=""
Then on the right side of the page, I clicked the “Preview SQL” button:
data:image/s3,"s3://crabby-images/205f7/205f72473ffba3629082dafa1db4c12135b03aa6" alt=""
Which made this small box appear with the SQL that is being executed:
data:image/s3,"s3://crabby-images/bfa7f/bfa7f3dbe08bebce3afa6b9e6a2b9baf117c41c6" alt=""
The actual SQL code for this table update is:
ALTER TABLE `usercardsetplaycounts` CHANGE `updatedAt` `updatedAt` TIMESTAMP on update CURRENT_TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP;
After closing this dialog, all I had to do was click the “Save” button to make this change to the database. Now whenever any row in this table is updated, the updatedAt column will contain a fresh timestamp for that row. Here is what the Structure looks like after the change:
data:image/s3,"s3://crabby-images/0ef6e/0ef6e6640a7b765130f276fb5f87aa05a32364f2" alt=""