Heim > Artikel > Backend-Entwicklung > Rufen Sie alle Daten aus der Mongodb-Composite-Sammlung mithilfe des Filters in Golang ab
Ich versuche, alle Daten über das Namensfeld abzurufen, das ich im API-Anfragetext angegeben habe. Ich habe einen Filter für die Funktion .find() erstellt. Aber ich kann keine Ergebnisse erhalten (Antworttext zeigt Null, überhaupt kein Fehler). Sie können meine Modelldatei und den Rest des Codes unten sehen.
Controller:
func get_formbypatientfullname(ctx *gin.context) { col := mongodb.client.database(config.database_name).collection("consentforms") filter := bson.m{"patient": bson.m{"name": ctx.query("name")}} cursor, err := col.find(_context.todo(), filter) if err != nil { log.fatal(err) } var results []general_models.consentform if err = cursor.all(_context.todo(), &results); err != nil { log.fatal(err) } for _, result := range results { res, _ := json.marshal(result) fmt.println(string(res)) } ctx.indentedjson(http.statusok, gin.h{"data": results}) }
Modelldatei:
type ConsentForm struct { ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"` FormFileURL string `json:"FormFileURL" bson:"FormFileURL"` ProcessName string `json:"ProcessName" bson:"ProcessName"` DateOfNotification string `json:"DateOfNotification" bson:"DateOfNotification"` WitnessName string `json:"WitnessName" bson:"WitnessName"` WitnessSurname string `json:"WitnessSurname" bson:"WitnessSurname"` ResponsibleDoctor string `json:"ResponsibleDoctor" bson:"ResponsibleDoctor"` Patient IPatient `json:"Patient" bson:"Patient"` QuestionOptions IQuestionOptions `json:"QuestionOptions" bson:"QuestionOptions"` AdditionalDetails string `json:"AdditionalDetails" bson:"AdditionalDetails"` } type IPatient struct { // ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"` Name string `json:"Name" bson:"Name"` Surname string `json:"Surname" bson:"Surname"` Birthdate string `json:"Birthdate" bson:"Birthdate"` TCKN string `json:"TCKN" bson:"TCKN"` FacePhotoURL string `json:"FacePhotoURL" bson:"FacePhotoURL"` SignatureImageURL string `json:"SignatureImageURL" bson:"SignatureImageURL"` }
Ich versuche, nach Benutzernamen zu filtern und alle Daten des Benutzers abzurufen. Aber ich glaube, ich habe einen Fehler im Filterteil oder im gesamten Code, weil ich keine Daten zurückbekomme. Was ich dafür bekomme, ist leer.
Ihr Filter sucht nach Dokumenten, die das Feld patient
是嵌入文档且具有与给定值匹配的单个 name
enthalten.
Um nach einem im Dokument eingebetteten Feld zu filtern, müssen Sie die Punktnotation verwenden:
filter := bson.M{"Patient.Name": ctx.Query("name")}
Das obige ist der detaillierte Inhalt vonRufen Sie alle Daten aus der Mongodb-Composite-Sammlung mithilfe des Filters in Golang ab. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!