Firestore查询未获取最新文档

时间:2020-08-11 07:54:07

标签: java android firebase google-cloud-firestore

我目前正在为一个小百货店的基本库存管理系统构建一个Android应用程序,而我想实现的一个功能是选择类别,该类别在被选择时将对产品进行过滤。我现在几乎只是在考虑这个想法,但是我目前已经设置了CardView,其中每个Card都包含一个按类别名称标记的按钮。我目前正在使用Google的Firestore存储我的所有信息,您可以在下面看到这些信息。 enter image description here

如您所见,当前有9个类别,每个类别包含一个不同的id值,从1开始到9结束。我希望能够在我的应用程序中添加新类别。所以我想为了添加新类别,我首先需要找到添加的最新类别,获取其ID值,将其递增1,然后用新名称(通过应用程序获取)编写新类别)和ID到数据库。这是第一次成功,但是,如果我开始连续地向数据库中添加项目,则每次单击按钮时似乎都找不到最新文档,例如,如果最新文档是ID值为9的“ ONAYBHFDTII6rcRbKxSf”那么第一次使用它将创建ID值为10的新文档,但是当我尝试添加第11个文档时,查询找不到先前创建的ID值为10的文档,而是再次使用了文档“ ONAYBHFDTII6rcRbKxSf” ,现在给了我两个ID值为10,但类别名称不同的文档。

我在执行该操作的方法下面粘贴了内容。此方法在我按钮的onClickListener()中调用。我首先使用AlertDialog输入新的类别名称,然后使用orderBy()limit()方法对最新文档进行读取,以获得最新的ID,然后将其递增并写入一个新文档返回数据库。

在谈到Firestore / Firebase时,我仍然很陌生,并且我试图更深入地研究它,因此我的问题是,我做错什么了吗?我的逻辑错了吗?如果可能的话,我想保留数据库的结构,但是如果绝对需要更改它以使其正常运行,那么我不会介意。

private void showTextDialog(View view)
    {
        AlertDialog.Builder builder = new AlertDialog.Builder(getContext());
        builder.setTitle("Enter Category");
        final EditText input = new EditText(getContext());
        input.setInputType(InputType.TYPE_CLASS_TEXT | InputType.TYPE_DATETIME_VARIATION_NORMAL);
        builder.setView(input);

        builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                final String newCategory = input.getText().toString();
                db = FirebaseFirestore.getInstance();
                newCategories = new HashMap<>();
                db.collection("categories")
                        .orderBy("id", Query.Direction.DESCENDING)
                        .limit(1)
                        .get()
                        .addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
                            @Override
                            public void onComplete(@NonNull Task<QuerySnapshot> task) {
                                int latestID = 0;
                                for(QueryDocumentSnapshot document : task.getResult())
                                {
                                    latestID = Integer.parseInt(document.get("id").toString());
                                    Log.d("Latest Document", document.getId().toString());
                                }
                                latestID++;
                                newCategories.put("id", latestID);
                                newCategories.put("categoryName", newCategory);
                                db.collection("categories")
                                        .add(newCategories)
                                        .addOnSuccessListener(new OnSuccessListener<DocumentReference>() {
                                            @Override
                                            public void onSuccess(DocumentReference documentReference) {
                                                Log.d("fragment", "Successfully added document");
                                                getCategories();
                                            }
                                        })
                                        .addOnFailureListener(new OnFailureListener() {
                                            @Override
                                            public void onFailure(@NonNull Exception e) {
                                                Log.d("fragment", "Failed to add document");
                                            }
                                        });
                            }
                        });


            }
        });
        builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                dialog.cancel();
            }
        });
        builder.show();
    }

1 个答案:

答案 0 :(得分:0)

我想出了解决上述小问题的方法。简而言之,请确保数据库中的所有值都完全相同。就我而言,某些id值是字符串而不是数字类型