gpt4 book ai didi

android - 使用查询从 Firestore 中高效地检索联系人数据

转载 作者:行者123 更新时间:2023-11-29 00:53:41 25 4
gpt4 key购买 nike

我的要求是,当用户 Mr.ABC 安装应用程序时,它将获取用户的所有联系人并保存到 Firebase Firestore。当另一个用户 Mr.XYZ 在他的设备上安装该应用程序时,它将获取 XYZ 的所有联系人并保存到 Firebase。同样,无论谁安装该应用程序,它都会获取联系人并保存到 Firebase Firestore。现在我的读取操作应该是,Mr.ABC 将在 EditText 和 firebase 中键入 XYZ 号码,我必须查看 XYZ 联系方式并找出 ABC 的号码并获取 XYZ 在他的联系人中保存的名称。这样当ABC输入XYZ号码时,ABC就可以查到XYZ用哪个名字保存了ABC的号码。请帮助我在 firebase 中保存联系人的结构以及如何读取数据。我想知道执行此操作的有效方法。由于我不擅长数据库,因此帮助我编写准确的代码会更有帮助。请帮忙。 enter image description here

我尝试了以下代码,但只有 800 个联系人存储到 Firestore 而不是 2500 个,而且我不确定我使用的数据库结构是对还是错。我对数据库的了解为零。

    private void doUploadContactstoCloud() {
dialog.setCancelable(false);
dialog.setMessage("Please wait we are configuring your request ...");
dialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);
dialog.show();
listContacts = new ContactPresenter(this).fetchAllContacts();
int j = listContacts.size();

Log.d("sizejhfg",j+"");

double size = listContacts.size();
double ind = 0;
Map<String, Object> contact = new HashMap<>();
// Get a new write batch
WriteBatch batch = db.batch();
for (Contact con : listContacts) {
for (int i = 0; i < con.numbers.size(); i++) {
String number = formatnum(con.numbers.get(i).number);
if (number != null) {
if (!number.equals("0") && number.length() < 5) {

Map<String, Object> contactnumber = new HashMap<>();
contactnumber.put("name", con.name);
contactnumber.put("number", number);
contact.put(number,contactnumber);
DocumentReference item = db.collection(tonumber).document(number);
batch.set(item,contactnumber);
ind++;
if(ind==500){
doCommit(batch);
batch=db.batch();
ind=0;
}
}
}
}
//dialog.setProgress((int) (ind / size) * 100);
}
if(ind>0){
doCommit(batch);
}
prefManager.setisContactUpload(true);
doDismissDialog();
}`

最佳答案

这是您问题的可能答案 -

首先,Firestore 数据库结构。我现在将其称为数据库结构。这是一个可能适合您的模板 -

c- Contacts
d- +1 9999999999 //ABC's Phone No.
f- +1 0000000000 : XYZ's Number // XYZ's Saved Name in ABC's Contacts and his phone no.
f- +1 1111111111 : LMN's Number // LMN's Saved Name in ABC's Contacts and his phone no.
d- +1 0000000000 //XYZ's Phone No.
f- +1 9999999999 : ABC's Number //ABC's Saved Name in XYZ's Contacts and his phone no.
f- +1 1111111111 : LMN's Number // LMN's Saved Name in XYZ's Contacts and his phone no.

其次,这是我认为可用于添加和查询数据库的代码 -

Map<String, Object> contacts = new HashMap<>();
contacts.put("+1 0000000000", "XYZ's Number");
contacts.put("+1 1111111111", "LMN's Number");

db.collection("contacts").document("+1 9999999999")
.set(contacts)
.addOnSuccessListener(new OnSuccessListener<Void>() {
@Override
public void onSuccess(Void aVoid) {
Log.d(TAG, "DocumentSnapshot successfully written!");
}
})
.addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
Log.w(TAG, "Error writing document", e);
}
});

编辑这部分以获得更高效的查询 -

db.collections("contacts").document("+1 9999999999").get(EditTextEnteredNumber)
.addOnSuccessListener(new OnSuccessListener<QuerySnapshot>() {
@Override
public void onSuccess(QuerySnapshot queryDocumentSnapshots) {
for (QueryDocumentSnapshot snap : queryDocumentSnapshots) {
Log.d(TAG, snap.getId() + " => " + snap.getData());
TextViewContactName.setText(snap.getData());
}
}
});

希望这对您有所帮助!

来源

关于android - 使用查询从 Firestore 中高效地检索联系人数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56967151/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com