FireBase按文档和集合进行多个查询

时间:2020-10-14 12:53:40

标签: android firebase kotlin google-cloud-firestore

我在用firebase奋力运行一个查询以使用truckDocumentId,然后再运行另一个查询以使用routeByDateDocumentId,最后我同时使用两个文档ID来运行功能“ sendGpsPosition”,我的问题是第一个查询找到truckDocumentId,但有时第二个查询不执行,这就是应用程序停止的原因。下面的代码用于Kotlin。

如果我正在调试,那么大部分时间都可以工作..如果我关闭调试,它将几乎显示以下错误=>

并且由于不执行查询,我得到了以下错误: java.lang.IllegalArgumentException:无效的文档引用。文档参考必须具有偶数个段,但卡车具有1

suspend fun getTruckId() {
    val trucksReference = firestore.collection("trucks").whereEqualTo("dispatcher", "Miro")
        .whereEqualTo("name", "PEUGEOT").get().await()
    val document = trucksReference.documents[0]
    if (document != null) {
        truckDocumentId = document.id
    }
}

suspend fun getRouteReferenceId() {
    val routesByDate = firestore.collection("trucks")
        .document(truckDocumentId)
        .collection("routes_by_date").get().await()
    val documentRoute = routesByDate.documents[0]
    if (documentRoute != null) {
        routesByDateDocumentId = documentRoute.id
    }
}


fun sendGpsPosition(lat: Double, long: Double, imageRef: String? = null) {
    runBlocking { getTruckId() } // if I get this DocumentID
    runBlocking { getRouteReferenceId() } // this here maybe will be not found or maybe will be found.. the async is not done correct not sure how to do it.
    firestore
        .collection("trucks")
        .document(truckDocumentId)
        .collection("routes_by_date")
        .document(routesByDateDocumentId)
        .collection("live_route")
        .add(LatLong(Timestamp.now(), lat, long))
}

1 个答案:

答案 0 :(得分:0)

 **I solved it this way.**

private suspend fun getTruckId() {
            val trucksReference = firestore.collection("trucks")
                .whereEqualTo("dispatcher", "Miro")
                .whereEqualTo("name", "VW")
                .get()
                .await()
            val document = trucksReference.documents[0]
            if (document != null) {
                truckDocumentId = document.id
            }
        }
    
        private suspend fun getRouteReferenceId() {
            val currentTime = Timestamp.now()
            val routesByDate = firestore.collection("trucks")
                .document(truckDocumentId)
                .collection("routes_by_date")
                .get()
                .await() // here will be better to look for data by delivery_day
            val documentRoute = routesByDate.documents[0]
            if (documentRoute != null) {
                routesByDateDocumentId = documentRoute.documents[0].id
            }
        }
    
        private fun addGpsDataInDatabase(lat: Double, long: Double, imageRef: String? = null) {
            firestore
                .collection("trucks")
                .document(truckDocumentId)
                .collection("routes_by_date")
                .document(routesByDateDocumentId)
                .collection("planned_route")  //planned_route or live_route depends if we want to show current state of a truck of make a route plan
                .add(LatLong(Timestamp.now(), lat, long))
        }
    
        fun sendGpsPosition(lat: Double, long: Double, imageRef: String? = null) {
            GlobalScope.launch {
                val truckDocId = async { getTruckId() }
                truckDocId.await()
                val routeDocId = async { getRouteReferenceId() }
                routeDocId.await()
                addGpsDataInDatabase(lat, long, imageRef)
            }
    
        }