Heim > Backend-Entwicklung > Golang > Rufen Sie alle Daten aus der Mongodb-Composite-Sammlung mithilfe des Filters in Golang ab

Rufen Sie alle Daten aus der Mongodb-Composite-Sammlung mithilfe des Filters in Golang ab

WBOY
Freigeben: 2024-02-06 10:36:13
nach vorne
671 Leute haben es durchsucht

Rufen Sie alle Daten aus der Mongodb-Composite-Sammlung mithilfe des Filters in Golang ab

Frageninhalt

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})
}
Nach dem Login kopieren

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"`
}
Nach dem Login kopieren

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.


Richtige Antwort


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")}
Nach dem Login kopieren

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!

Quelle:stackoverflow.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage