我目前正在为一个小百货店的基本库存管理系统构建一个Android应用程序,而我想实现的一个功能是选择类别,该类别在被选择时将对产品进行过滤。我现在几乎只是在考虑这个想法,但是我目前已经设置了CardView,其中每个Card都包含一个按类别名称标记的按钮。我目前正在使用Google的Firestore存储我的所有信息,您可以在下面看到这些信息。
如您所见,当前有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();
}
答案 0 :(得分:0)
我想出了解决上述小问题的方法。简而言之,请确保数据库中的所有值都完全相同。就我而言,某些id值是字符串而不是数字类型