MongoDB에서는 문서 필드에 대한 기본 타임스탬프를 정의하는 것이 일반적입니다. 그러나 Go with Mgo에는 필드의 기본값을 설정하는 직접적인 방법이 없습니다.
한 가지 접근 방식은 기본값을 채우는 사용자 정의 생성자 함수를 만드는 것입니다.
func NewUser() *User { return &User{ CreatedAt: time.Now(), } }
이렇게 하면 이 생성자를 사용하여 생성된 모든 새 User 구조체가 기본 CreatedAt를 갖게 됩니다. field.
또 다른 옵션은 BSON의 bson.Getter 인터페이스를 사용하여 사용자 정의 직렬화 논리를 구현하는 것입니다.
func (u *User) GetBSON() (interface{}, error) { if u.CreatedAt.IsZero() { u.CreatedAt = time.Now() } type my *User return my(u), nil }
사용자를 BSON으로 마샬링할 때 이 GetBSON 함수가 호출되고 아직 시간이 아닌 경우 CreatedAt 필드를 현재 시간으로 채웁니다. set.
두 가지 접근 방식을 사용하면 기존 문서를 업데이트하는 경우에도 CreatedAt 필드가 현재 시간으로 덮어쓰여집니다. 이를 방지하려면 GetBSON에 검사를 추가하여 필드가 0인 경우에만 필드를 설정하면 됩니다.
또한 사용자 정의 마샬링 접근 방식을 사용하려면 time.Time이 포함된 모든 유형에 대해 bson.Getter를 구현해야 합니다. 기본값이 있는 필드입니다.
위 내용은 Go의 Mgo를 사용하여 MongoDB 문서의 기본 날짜를 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!