【问题标题】:Speed of search operation in a Realm databaseRealm 数据库中的搜索操作速度
【发布时间】:2017-02-06 03:35:39
【问题描述】:

这是我的RealmObject 课程的模型:

    public class ARDatabase extends RealmObject
    {
    @PrimaryKey
    private String uid;

    private String namex;
    private String desc;
    private boolean isVideo;
    private boolean isDeleted;
    private String urlImg;
    private String urlApp;
    private int updates;
    private boolean isDownloaded;
    private String location;

    public ARDatabase(){}

    public String getUid()
    {
        return uid;
    }

    public void setUid(String uid)
    {
        this.uid = uid;
    }

    public String getNamex()
    {
        return namex;
    }

    public void setNamex(String namex)
    {
        this.namex = namex;
    }

    public String getDesc()
    {
        return desc;
    }

    public void setDesc(String desc)
    {
        this.desc = desc;
    }

    public boolean getIsVideo()
    {
        return isVideo;
    }

    public void setIsVideo(boolean isVideo)
    {
        this.isVideo = isVideo;
    }

    public boolean getIsDeleted()
    {
        return isDeleted;
    }

    public void setIsDeleted(boolean isDeleted)
    {
        this.isDeleted = isDeleted;
    }

    public String getUrlImg()
    {
        return urlImg;
    }

    public void setUrlImg(String urlImg)
    {
        this.urlImg = urlImg;
    }

    public String getUrlApp()
    {
        return urlApp;
    }

    public void setUrlApp(String urlApp)
    {
        this.urlApp = urlApp;
    }

    public int getUpdates()
    {
        return updates;
    }

    public void setUpdates(int updates)
    {
        this.updates = updates;
    }

    public boolean getIsDownloaded()
    {
        return isDownloaded;
    }

    public void setIsDownloaded(boolean isDownloaded)
    {
        this.isDownloaded = isDownloaded;
    }

    public String getLocation()
    {
        return location;
    }

    public void setLocation(String location)
    {
        this.location = location;
    }
}

这就是我从默认领域搜索uid 的方式:

final ARDatabase db = mRealm.where(ARDatabase.class).equalTo("uid",imageTitles.get(result)).findFirst();

现在,问题是:考虑到我的领域内有 10-100 个对象,搜索速度有多快?

该用例用于图像识别应用。当应用识别图像时,它会返回uid,并且基于uid,我需要尽快在屏幕上提供与uid 相关联的信息。

现在由于我有大约 10-100 个对象,线性搜索 O(n) 或通用二进制搜索 O(log n) 会比我上面使用的 Realm 搜索更快吗?或者是否可以调整Realm 以获得更快的结果? (以防它现在没有以最快的方式执行)。

【问题讨论】:

    标签: java android performance search realm


    【解决方案1】:

    在 Realm 中进行搜索总是会更快,因为您可以在 C++ 内核中执行整个搜索。自己进行搜索意味着您会产生在 Java 和 C++ 之间来回切换的开销。

    快速搜索单个元素的唯一要求是您在该字段上有一个@Index 注释,但在您的情况下,您已经有@PrimaryKey,它也会自动应用@Index 注释。

    所以您的查询尽可能快。此外,对于 10 到 100 个对象,无论您做什么,它都可能会立即出现在用户面前。

    【讨论】:

    • 感谢您完美地澄清它:)
    • 另外,如果查询是从 UI 线程运行的,则可能值得使用 findFirstAsync 并使用更改侦听器。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-01-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-05-13
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多