詳解Spring data 定義默認時間與日期的實例
詳解Spring data 定義默認時間與日期的實例
前言:
需求是這樣的:
1. 創(chuàng)建時間與更新時間只能由數(shù)據(jù)庫產生,不允許在實體類中產生,因為每個節(jié)點的時間/時區(qū)不一定一直。另外防止人為插入自定義時間時間。
2. 插入記錄的時候創(chuàng)建默認時間,創(chuàng)建時間不能為空,時間一旦插入不允許日后在實體類中修改。
3. 記錄創(chuàng)建后更新日志字段為默認為 null 表示該記錄沒有被修改過。一旦數(shù)據(jù)被修改,修改日期字段將記錄下最后的修改時間。
4. 甚至你可以通過觸發(fā)器實現(xiàn)一個history 表,用來記錄數(shù)據(jù)的歷史修改,詳細請參考作者另一部電子書《Netkiller Architect 手札》數(shù)據(jù)庫設計相關章節(jié)。
10.1.6. 默認時間規(guī)則
10.1.6.1. CreatedDate
Spring 提供了 import org.springframework.data.annotation.CreatedDate;
但是這些只能作用于實體類。
@CreatedDate private Date createdDateTime;
10.1.6.3. 數(shù)據(jù)庫級別的默認創(chuàng)建日期時間定義
package cn.netkiller.api.domain.elasticsearch;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table
public class ElasticsearchTrash {
@Id
private int id;
@Column(columnDefinition = "TIMESTAMP DEFAULT CURRENT_TIMESTAMP")
private Date ctime;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public Date getCtime() {
return ctime;
}
public void setCtime(Date ctime) {
this.ctime = ctime;
}
}
對應數(shù)據(jù)庫DDL
CREATE TABLE `elasticsearch_trash` ( `id` int(11) NOT NULL, `ctime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
10.1.6.4. 數(shù)據(jù)庫級別的默認創(chuàng)建日期與更新時間定義
需求是這樣的:
1. 創(chuàng)建時間與更新時間只能由數(shù)據(jù)庫產生,不允許在實體類中產生,因為每個節(jié)點的時間/時區(qū)不一定一直。另外防止人為插入自定義時間時間。
2. 插入記錄的時候創(chuàng)建默認時間,創(chuàng)建時間不能為空,時間一旦插入不允許日后在實體類中修改。
3. 記錄創(chuàng)建后更新日志字段為默認為 null 表示該記錄沒有被修改過。一旦數(shù)據(jù)被修改,修改日期字段將記錄下最后的修改時間。
4. 甚至你可以通過觸發(fā)器實現(xiàn)一個history 表,用來記錄數(shù)據(jù)的歷史修改,詳細請參考作者另一部電子書《Netkiller Architect 手札》數(shù)據(jù)庫設計相關章節(jié)。
package cn.netkiller.api.domain.elasticsearch;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.validation.constraints.Null;
@Entity
@Table
public class ElasticsearchTrash {
@Id
private int id;
// 創(chuàng)建時間
@Column(insertable = false, updatable = false, columnDefinition = "TIMESTAMP DEFAULT CURRENT_TIMESTAMP")
private Date ctime;
// 修改時間
@Column(nullable = true, insertable = false, updatable = false, columnDefinition = "TIMESTAMP NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP")
private Date mtime;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public Date getCtime() {
return ctime;
}
public void setCtime(Date ctime) {
this.ctime = ctime;
}
public Date getMtime() {
return mtime;
}
public void setMtime(Date mtime) {
this.mtime = mtime;
}
}
對應數(shù)據(jù)庫DDL
CREATE TABLE `elasticsearch_trash` ( `id` int(11) NOT NULL, `ctime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `mtime` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8
10.1.6.5. 最后修改時間
需求:記錄最后一次修改時間
package cn.netkiller.api.domain.elasticsearch;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table
public class ElasticsearchTrash {
@Id
private int id;
@Column(columnDefinition = "TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP")
private Date lastModified;
}
產生DDL語句如下
CREATE TABLE `elasticsearch_trash` ( `id` int(11) NOT NULL, `ctime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
以上就是Spring data 定義默認時間與日期的實例,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
JSP技術實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方法
實現(xiàn)動態(tài)頁面到靜態(tài)頁面以減小數(shù)據(jù)庫與服務器的壓力和負擔,這是很多實際開發(fā)應用工作當中的一個理想的解決辦法,那么本文就向你講解如何實現(xiàn)實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方案。2016-10-10
jsp中頁面之間的跳轉forward與sendRedirect的區(qū)別
頁面之間的跳轉可以通過兩種方式實現(xiàn):forward和sendRedirect;forward:可以在JSP頁面中使用,可以在Servlet中實現(xiàn),需要的朋友可以了解下2012-12-12
jsp項目中更改tomcat的默認index.jsp訪問路徑的方法
如何更改tomcat的默認index.jsp訪問路徑,jsp的工程下有一個叫做WEB-INF文件夾下的web.xml打開它,按照下面的方法即可修改2013-11-11
基于jsp+servlet實現(xiàn)的簡單博客系統(tǒng)實例(附源碼)
這篇文章主要介紹了基于jsp+servlet實現(xiàn)的簡單博客系統(tǒng),以完整實例形式分析了基于jsp+servlet簡單博客系統(tǒng)的原理與相關技巧,并附帶了完整源碼供讀者下載學習,需要的朋友可以參考下2015-09-09
jsp實現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法
下面小編就為大家分享一篇jsp實現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01

