MySQL是目前世界上最流行的關系型數(shù)據(jù)庫管理系統(tǒng)之一,它的數(shù)據(jù)字典中還規(guī)定了一些自動生成的字段,包括兩個timestamp字段和兩個int字段,這些字段分別是:
create_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時間', update_time timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時間', is_deleted tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否刪除:0-未刪除,1-已刪除', version int(11) NOT NULL DEFAULT '0' COMMENT '版本號'
在創(chuàng)建數(shù)據(jù)表時,如果沒有顯式地指定這些字段的屬性,則將自動使用默認值。這些字段的作用是增強數(shù)據(jù)表的記錄追蹤、版本管理和數(shù)據(jù)刪除防護功能。
其中,create_time
列用來記錄該記錄的創(chuàng)建時間,update_time
列用來記錄該記錄最近一次修改的時間,這兩列都使用了timestamp類型,即自動記錄時間戳。對于update_time
列,設置了ON UPDATE CURRENT_TIMESTAMP
屬性,意味著在每次更新時將自動更新該列的值為當前時間戳。
is_deleted
列用來標識該記錄是否被標記為“已刪除”,取值為0或1,是一種輕量級的軟刪除方式。當需要刪除一條記錄時,只需要將該列的值設置為1即可,查詢時過濾掉已被標記為“已刪除”的記錄即可實現(xiàn)該功能。
version
列用來記錄數(shù)據(jù)的版本號,每次對該記錄進行更新時,該列的值將自動加1。該功能主要用于樂觀鎖機制,用于在并發(fā)情況下控制數(shù)據(jù)的一致性。