Go에서 Time.Time 필드를 사용하여 문서 삽입 시 기본 날짜 설정
Go에서는 Node.js의 Mongoose와 달리 기본값을 사용할 수 없습니다. 구조체 정의 내의 필드에 할당됩니다. 동일한 결과를 얻으려면 여러 가지 접근 방식을 사용할 수 있습니다.
한 가지 방법은 새 구조체를 인스턴스화하고 CreatedAt 필드를 현재 시간으로 설정하는 생성자와 같은 함수를 만드는 것입니다. 그런 다음 이 기능을 활용하여 새로운 사용자를 생성할 수 있으며 필드가 일관되게 설정되도록 할 수 있습니다.
func NewUser() *User { return &User{ CreatedAt: time.Now(), } }
그러나 이 접근 방식은 새로운 사용자를 생성하기 위해 이 기능을 사용하는 데 엄격한 준수가 필요하고 캡처하지 않기 때문에 한계가 있습니다. 문서 삽입의 타임스탬프.
더 다양한 솔루션은 bson.Getter 인터페이스를 구현하여 사용자 정의 마샬링 논리를 구현하는 것입니다. GetBSON() 메서드를 사용하면 데이터베이스에 저장된 값을 수정할 수 있습니다.
type User struct { CreatedAt time.Time `json:"created_at" bson:"created_at"` } func (u *User) GetBSON() (interface{}, error) { if u.CreatedAt.IsZero() { u.CreatedAt = time.Now() } type my *User return my(u), nil }
이 메서드는 CreatedAt 필드가 비어 있는지 확인하고 비어 있으면 현재 시간으로 설정합니다. 또한 bson.Getter 인터페이스를 구현하지 않는 새로운 유형을 반환하여 스택 오버플로를 방지합니다.
이 접근 방식을 사용하면 문서가 저장될 때마다 CreatedAt 필드가 자동으로 업데이트되고 필드에 이미 포함된 경우 이를 덮어쓰지 않습니다. 가치. 이는 더 큰 유연성을 제공하고 문서 삽입 중 기본값 설정의 예상 동작과 일치합니다.
위 내용은 Go에서 문서 삽입 시 기본 날짜 및 시간을 설정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!