Получить данные о базе данных от Swift - PullRequest
0 голосов
/ 24 апреля 2019

Я пытаюсь получить данные из базы данных Firebase RealTime, чтобы поместить их в список, который будет использоваться для отображения данных в TableView.

Моя проблема в том, что даже если я получаю некоторые данные, у меня недостаточно знаний для доступа к массивам и другим быстрым объектам. Возможно, я не использую хороший способ делать то, что я хочу.

Вот пример строки в Firebase:

enter image description here

Вот функция, написанная на Swift, в которой я пытаюсь построить список для каждого объекта строки.

func displayStationsUsingSearch(){


    let station = self.stationName
    let CP = Int(self.searchedCP!)

    // create searchRef or queryRef you name it
    let stationsRef = Database.database().reference().child("Stations")
    stationsRef.observeSingleEvent(of: .value, with: { (snapshot) in
        print(snapshot)
        /*if snapshot.value is NSNull {
            print("not found")
        } else {
            // yes we got the user
            let id = snapshot.value as! Int
        }*/
        for child in snapshot.children {

            stationsRef.queryOrdered(byChild: "marque")
                .queryEqual(toValue: "TOTAL ACCESS")
                .observe(.value, with: { snap in

                    if let dict = snap.value as? [String: AnyObject] {
                        /*self.stationItem!.nomStation = dict["nomStation"] as! String
                        self.stationItem!.adresse = dict["adresse"] as! String
                        self.stationItem!.codePostal = dict["codePostal"] as! String
                        self.stationItem!.ville = dict["ville"] as! String
                        self.stationItem!.marque = dict["marque"] as! String
                        self.stationItem!.pays = dict["pays"] as! String
                        self.stationItem!.commentaire = dict["commentaire"] as! String
                        self.stationItem!.coordGPS = dict["coordGPS"] as! String*/
                        print(dict["nomStation"] as! String)
                    }
            })

        }
    })
}

lldb в рабочем пространстве Xcode показывает, что:

Printing description of child:
Snap (-LdA6X8CfNY3bsPni31U) {
"DIESEL EXCELLIUM" = 0;
"DIESEL ULTIMATE" = 0;
GAZOLE = 0;
GPL = 0;
SP95 = 0;
"SP95 E10" = 0;
SP98 = 0;
SUPER = 0;
adresse = "RN1 Direction Moisselles";
codePostal = 95570;
commentaire = "";
coordGPS = "";
createdAt = "31/07/2018";
heureDebut = "";
heureFin = "";
id = 0;
marque = ESSO;
modifiedAt = "23/04/2019 18:53";
nomStation = "ESSO Moisselles";
pays = "";
saufJour = "";
services = "";
typeRoute = "";
ville = Moisselles;
}
(lldb) 

Не могли бы вы помочь мне извлечь данные из списка, который я мог бы добавить для отображения данных в виде таблицы? Спасибо.

1 Ответ

0 голосов
/ 24 апреля 2019

Попробуйте что-то подобное:

Database.database().reference()
  .child("Stations").
  observeSingleEvent(of: .value, with: { (snapshot) in 
    guard let value = snapshot.value as? [String: Any] else {
      return
    }

    var stations = [Station]()
    for (key, value) in values {
      guard let station = value as? [String: Any],
          let adresse = station["adresse"] as? String,
          let codePostat = station["codePostat"] as? String else {
              continue
          }
          stations.append(Station(adresse: adresse, codePostat: codePostat))
    }

    // if you have some completion return retrieved array of stations
    completion(stations)
})

struct Station {

  private let adresse: String
  private let codePostat: String

  init(adresse: String, codePostat: String) {

    self.adresse = adresse
    self.codePostat = codePostat
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...