亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

詳解Spring data 定義默認時間與日期的實例

2020-07-27 21:21:01
字體:
來源:轉載
供稿:網友

詳解Spring data 定義默認時間與日期的實例

前言:

需求是這樣的:

1. 創建時間與更新時間只能由數據庫產生,不允許在實體類中產生,因為每個節點的時間/時區不一定一直。另外防止人為插入自定義時間時間。

2. 插入記錄的時候創建默認時間,創建時間不能為空,時間一旦插入不允許日后在實體類中修改。

 3. 記錄創建后更新日志字段為默認為 null 表示該記錄沒有被修改過。一旦數據被修改,修改日期字段將記錄下最后的修改時間。

4. 甚至你可以通過觸發器實現一個history 表,用來記錄數據的歷史修改,詳細請參考作者另一部電子書《Netkiller Architect 手札》數據庫設計相關章節。

10.1.6. 默認時間規則

10.1.6.1. CreatedDate

Spring 提供了 import org.springframework.data.annotation.CreatedDate;

但是這些只能作用于實體類。

@CreatedDate  private Date createdDateTime;

10.1.6.3. 數據庫級別的默認創建日期時間定義

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@Tablepublic 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; }}

對應數據庫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. 數據庫級別的默認創建日期與更新時間定義

需求是這樣的:

1. 創建時間與更新時間只能由數據庫產生,不允許在實體類中產生,因為每個節點的時間/時區不一定一直。另外防止人為插入自定義時間時間。

2. 插入記錄的時候創建默認時間,創建時間不能為空,時間一旦插入不允許日后在實體類中修改。

3. 記錄創建后更新日志字段為默認為 null 表示該記錄沒有被修改過。一旦數據被修改,修改日期字段將記錄下最后的修改時間。

4. 甚至你可以通過觸發器實現一個history 表,用來記錄數據的歷史修改,詳細請參考作者另一部電子書《Netkiller Architect 手札》數據庫設計相關章節。

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@Tablepublic class ElasticsearchTrash { @Id private int id; // 創建時間 @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; }}

對應數據庫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@Tablepublic 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 定義默認時間與日期的實例,如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91地址最新发布| 国产精品女人久久久久久| 欧美精品videossex88| 在线视频亚洲欧美| 国产午夜精品麻豆| 欧美风情在线观看| 日韩有码在线电影| 成人国产精品久久久| 亚洲xxxx在线| 中文字幕亚洲欧美日韩2019| 国产精品中文久久久久久久| 久久久人成影片一区二区三区| 精品美女久久久久久免费| 国产精品久久久久久久久久久新郎| 国产激情视频一区| 日韩av免费观影| 国产精品日韩av| 欧美激情精品久久久久久大尺度| 日韩精品亚洲元码| 97色伦亚洲国产| 成人观看高清在线观看免费| 日韩在线视频免费观看| 欧美成人午夜视频| 欧美一区二区三区免费视| 91免费观看网站| 国产精品嫩草影院久久久| 97超视频免费观看| 久久av资源网站| 亚洲色图激情小说| 在线免费观看羞羞视频一区二区| 欧美黑人又粗大| 亚洲护士老师的毛茸茸最新章节| 国产精品入口福利| 欧美一区深夜视频| 一区二区欧美在线| 国内精品久久久久久影视8| 国产精品美女在线观看| 91精品国产自产在线观看永久| 国产精品流白浆视频| 日韩精品欧美激情| 亚洲国产天堂久久国产91| 91产国在线观看动作片喷水| 色综合久久88色综合天天看泰| 国产精品一区二区久久久| 亚洲香蕉av在线一区二区三区| 国产成人精品日本亚洲专区61| 欧美精品videossex88| 日韩毛片在线观看| 成人性生交大片免费观看嘿嘿视频| 欧美色videos| 国产欧美亚洲视频| 欧美一区亚洲一区| 欧美成人网在线| 日韩禁在线播放| 国产视频精品va久久久久久| 精品久久久免费| 久久精品国产欧美亚洲人人爽| 久久影院模特热| 亚洲第一免费网站| 欧美福利在线观看| 日韩美女中文字幕| 欧美黑人狂野猛交老妇| 91国内产香蕉| 欧美激情亚洲视频| 亚洲精品视频在线观看视频| 在线看国产精品| 国产精品香蕉在线观看| 亚洲国产一区二区三区在线观看| 国产一区二区视频在线观看| 欧美日韩在线一区| 中文字幕久久亚洲| 久久91精品国产91久久跳| 91精品国产综合久久香蕉922| 成人午夜激情免费视频| 精品爽片免费看久久| 精品福利免费观看| 亚洲欧美日韩中文在线制服| 日韩最新在线视频| 在线电影av不卡网址| 久久亚洲精品中文字幕冲田杏梨| 97国产精品免费视频| 成人女保姆的销魂服务| 欧美高跟鞋交xxxxhd| 精品伊人久久97| 久热在线中文字幕色999舞| 亚洲在线一区二区| 日韩美女主播视频| 精品偷拍各种wc美女嘘嘘| 精品久久香蕉国产线看观看亚洲| 亚洲欧美激情在线视频| 亚洲国产精品久久久久秋霞蜜臀| 亚洲高清久久久久久| 日韩成人网免费视频| 欧美成人精品一区| 中文字幕av一区二区| 色综合久综合久久综合久鬼88| 欧美xxxx18国产| 亚洲一区二区在线播放| 国产亚洲一区二区在线| 91在线|亚洲| 亚洲性猛交xxxxwww| www.日韩视频| 热久久99这里有精品| 国产在线日韩在线| 欧美大成色www永久网站婷| 成人国产精品色哟哟| 国产福利精品在线| 91在线观看免费高清| 国产亚洲欧洲黄色| 日韩av免费在线看| 国产精品入口福利| 中文字幕一区电影| 91香蕉电影院| 国产999精品| 91高清免费在线观看| 久久久欧美精品| 亚洲欧美成人一区二区在线电影| 国自产精品手机在线观看视频| 岛国av一区二区| 久久手机精品视频| 亚洲福利精品在线| 在线观看日韩www视频免费| 尤物九九久久国产精品的特点| 欧美日韩午夜视频在线观看| 中文字幕亚洲综合久久| 青草青草久热精品视频在线观看| 98精品国产自产在线观看| 在线观看精品国产视频| 欧美国产日韩在线| 欧美成人在线免费| 欧美黑人巨大xxx极品| 国产福利精品av综合导导航| 欧美在线视频观看免费网站| 欧美一级成年大片在线观看| 久久综合久久美利坚合众国| 一区二区三区视频在线| 亚洲色图色老头| 日韩电影大片中文字幕| 久久精品中文字幕电影| 亚洲精品电影网| 韩国国内大量揄拍精品视频| 日韩欧美国产激情| 欧美激情精品久久久久久久变态| 国产精品欧美日韩| 欧美久久精品一级黑人c片| 精品日韩中文字幕| 亚洲午夜精品久久久久久久久久久久| 在线丨暗呦小u女国产精品| 日韩欧美精品在线观看| 九九热r在线视频精品| 欧美精品日韩www.p站| 九九综合九九综合| 在线成人一区二区| 欧美激情二区三区| 欧美一区二区三区艳史| 久久久久久久久久久免费| 久久精品视频在线观看| 中文字幕不卡在线视频极品| 亚洲精品一区二三区不卡| 国产精品综合久久久| 日韩欧美中文免费| 国产精品免费一区豆花| 亚洲天堂第二页| 国产中文日韩欧美|