2

如果我们想获得一个对象 ID,我们应该这样做:

String objectId = gameScore.getObjectId();

但是如果我们想通过查询获得对象 ID 怎么办?像这样:

ParseQuery<ParseObject> query = ParseQuery.getQuery("mytable");
query.whereEqualTo("Title", "Adrians Book");

List<ParseObject> results = null;

 try {

        results = query.find();

        if(!results.isEmpty()) {
        String objectId = results.getObjectId();
        }

    } catch (com.parse4cn1.ParseException e) {

        Dialog.show("Err", "Something went wrong.", "OK", null);
    }

你不觉得听起来很有趣吗?我希望这是可能的。正如您在此示例中看到的,查询将从表中的特定对象获取一个值,该值可以跟踪对象 ID,然后也返回它。ParseQuery 类应该用 getObjectId() 来实现。因为通过这种方式,即使在应用程序重新启动后,应用程序也始终可以从查询中访问对象 ID,因此在第一个示例中,实际上是 ParseObject 实例的 gameScore 将在重新启动后失去对数据库的引用。通过查询获取对象 ID,它将能够对应用程序进行编程以自动获取对象 ID,而无需手动操作,也无需依赖 ParseObject 的实例。

4

2 回答 2

1

@Shai Almog:非常感谢您花时间查看 ParseQuery 文档。我不小心想出了如何完成这项工作!

ParseQuery<ParseObject> query = ParseQuery.getQuery("mytable");
query.whereEqualTo("Title", "Adrians Book");

List<ParseObject> results = null;

 try {
        results = query.find();
        if(!results.isEmpty()) {
        String objectId = results.get(0).getObjectId();
        System.out.println(objectId);
        }

    } catch (com.parse4cn1.ParseException e) {

        Dialog.show("Err", "Something went wrong.", "OK", null);
    }

是的,添加方法 .get(index) 后,它允许您访问方法 .getObjectId(),因为 results 是 ParseObject 的列表,然后查询结果的相应 objectId 将打印在控制台中!我很高兴它正在工作,因为我现在不需要序列化每个对象,这会很痛苦。

此外,如果您想使用现有 objectId 设置 ParseObject 的实例,以防您需要更新数据库中的某些内容,您可以使用以下示例:

ParseObject po = ParseObject.create("mytable");
po.setObjectId(//YOUR DESIRED OBJECTID HERE, AS LONG AS IT EXISTS IN THE DATABASE);
于 2018-03-30T05:03:16.920 回答
0

据我所知,您需要获取整个对象然后查询它的 ID。我在这里没有看到查询 id 方法https://github.com/sidiabale/parse4cn1/blob/41fe491699e604fc6de46267479f47bc422d8978/src/com/parse4cn1/ParseQuery.java

于 2018-03-30T04:08:12.227 回答