Heim  >  Artikel  >  Backend-Entwicklung  >  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
WBOYnach vorne
2024-02-06 10:36:13643Durchsuche

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})
}

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.


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")}

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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen