Android 的光标窗口大小似乎有 1MB 的限制,这限制了从 SQLite 读取 BLOB 的能力。我知道您可能会说我们不应该将 BLOB 存储在数据库中,但根据定义,BLOB 被视为二进制大对象,如果不需要将它们存储在数据库中,则无需在任何数据库引擎中实现此类对象类型。
然而,Cursor 实现的 1 MB 限制似乎在几乎所有情况下都不够。出于正当原因,我需要将二进制数据存储在 SQLite 数据库中,并且它们远远超过 1 MB。 SQLite 能够完美地处理 BLOB,因为 C API 在 Xcode(iPhone 平台)中运行得非常好,可以毫无问题地检索大型对象。
我想知道我们是否可以在不使用游标的情况下访问 Android 中的 BLOB 数据。我正在考虑在 Java 中对 Sqlite 进行较低级别的访问。有什么建议么?
正如CL提到的,使用NDK确实是Java语言中通过C语言原生访问Sqlite的一种方式。然而我意识到,如果我想自己编写一个自定义包装器并尝试访问 Java 中的函数,事情可能会变得非常混乱。
经过一番搜索,我发现了一个名为 Sqlite4java 的出色开源项目,它是 Sqlite 的紧密包装器,经过编译可在包括 Android 在内的各种平台上使用。该库允许您与 Sqlite 交互,而无需使用 Android Cursor,从而消除了限制。
我能够在 480 毫秒内检索 20 MB 的 Blob。这甚至比通过游标从 Sqlite 读取一条小记录还要快。我相信这可以通过跳过 Cursor 的使用来增强对 Sqlite 的任何查询。这是这个很棒的图书馆的链接:http://code.google.com/p/sqlite4java/
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)