Go에서 MongoDB 유형에 대한 마샬링/비마샬링 사용자 정의
Go에서 MongoDB에 액세스할 때 값을 변환해야 하는 상황이 발생할 수 있습니다. 마샬링/역마샬링. MongoDB에 문자열로 저장된 EndDate 필드에 액세스하는 경우를 생각해 보세요. 하지만 Go time.Time 유형으로 필요합니다.
이러한 시나리오를 해결하려면 bson을 사용하여 사용자 정의 마샬링/비마샬링 논리를 구현할 수 있습니다. Getter 및 bson.Setter 인터페이스. 다음은 단계별 가이드입니다.
type clientConfigData struct { SMTPAssoc int `bson:"smtp_assoc"` PlanType string `bson:"plan_type"` EndDateStr string `bson:"end_date"` EndDate time.Time `bson:"-"` }
const endDateLayout = "2006-01-02 15:04:05" // Specify your preferred date layout func (c *clientConfigData) SetBSON(raw bson.Raw) (err error) { type my clientConfigData if err = raw.Unmarshal((*my)(c)); err != nil { return } c.EndDate, err = time.Parse(endDateLayout, c.EndDateStr) return } func (c *clientConfigData) GetBSON() (interface{}, error) { c.EndDateStr = c.EndDate.Format(endDateLayout) type my *clientConfigData return my(c), nil }
SetBSON()에서 원시 MongoDB 값으로 구조체를 채우고 구문 분석합니다. EndDateStr을 time.Time으로 변환합니다. GetBSON()에서 EndDateStr을 설정하고 반환합니다.
문서를 찾거나 삽입할 때 다음을 사용하는 것을 잊지 마세요. clientConfigData를 지정하여 사용자 정의 마샬링/역마샬링 논리 type.
var configRes = new(clientConfigData) err := clientDB. C(clientConfigCollection). Find(bson.M{}). One(&configRes) if err != nil { return nil, errors.Wrap(err, "finding config collection") }
사용자 정의 마샬링/역마샬링을 구현하면 특정 유형 변환이 필요한 MongoDB 값을 원활하게 사용할 수 있습니다. 마샬링과 역마샬링을 모두 처리하려면 SetBSON() 및 GetBSON()을 모두 처리해야 합니다.
위 내용은 Go에서 MongoDB 유형에 대한 마샬링/비마샬링을 사용자 정의하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!