无需光标即可在 Android Sqlite 中访问大型 BLOB

2023-11-24

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(使用前将#替换为@)

无需光标即可在 Android Sqlite 中访问大型 BLOB 的相关文章

随机推荐

  • 使用Python代码清除控制台时如何修复“TERM环境变量未设置”?

    我使用 Pycharm 当我运行这个 Python 代码时 os system clear 我收到此错误 未设置 TERM 环境变量 在 Python 控制台的变量中 我输入 export TERM xterm 我还可以做些什么 尝试这个配
  • gnuplot:填充面积曲线,使抽动保持在顶部

    在 gnuplot 中 当您尝试填充曲线下的区域时 两个轴的抽动都会隐藏在实体区域后面 有什么办法可以让他们到前面去吗 我正在使用 postcript 终端 其中不允许透明功能 我猜 谢谢 肯定有 在绘图之前 以交互方式或在脚本中运行此命令
  • 无法连接(空)::selectionChanged 为 QTableView

    我有以下升级的 QTableView class QRightClickableTableView public QTableView Q OBJECT public explicit QRightClickableTableView QW
  • 如何在不禁用上下文菜单的情况下拦截 UITextView 上的长按?

    我想拦截 UITextview 上的长按 但不想同时禁用上下文菜单选项 如果我在文本视图上使用手势识别器 它将禁用上下文菜单 所以我现在使用如下方法 BOOL canPerformAction SEL action withSender i
  • Spring webflux 错误处理程序:如何在错误处理程序中获取请求的反应器上下文?

    Spring boot 2 1 5 项目 Reactor 3 2 9 在我的 webflux 项目中 我广泛使用反应器上下文来传递一些值 我的目的是能够获取异常处理程序内部的上下文 一个简单的例子 Component Order 2 pub
  • 如何在 SwiftUI 中设置清晰/透明背景的导航栏?

    我试图弄清楚如何为自定义导航栏编写代码以显示清晰 透明的栏而不是 白色 栏 看这个截图 这是我的代码 import SwiftUI struct ContentView View init UINavigationBar appearanc
  • Zend Framework 2:如何在应用程序到达控制器之前将重定向放入模块中

    假设我们有一个名为 Cart 的模块 并且希望在满足某些条件时重定向用户 我想在应用程序到达任何控制器之前在模块引导阶段放置重定向 所以这是模块代码 我想使用Url控制器插件 但似乎现阶段控制器实例不可用 至少我不知道如何获取它 提前致谢
  • 如何在IdentityServer4中进行多步登录?

    我们使用 IdentityServer3 隐式授权并且登录由多个屏幕组成 在 IdentityServer3 中 内置了对此类多步骤登录工作流程的支持 例如接受 EULA 双因素登录等 该功能称为 部分登录 甚至还有一个例子 https g
  • 在 Eclipse 中使用 Ant 的类路径

    我有一只蚂蚁build xml文件在命令行上运行得很好 它编译 构建 JAR 并且我能够从 JAR 中很好地执行 main 方法 这build xml文件引用了分散在各处的几个第三方库 构建 JAR 时 脚本不会将所有第三方库包含到 JAR
  • 这是从数组哈希中获取公共元素的最佳方法吗?

    我正在尝试从 Ruby 中的一组数组中获取一个公共元素 通常 您可以使用 运算符来比较两个数组 返回两个数组中存在或共有的元素 这一切都很好 除非您试图从多个对象中获取共同元素two数组 但是 我想从未知的动态数组数量 它们存储在哈希中 我
  • 如何处理原始可空类型的 Spark UDF 输入/输出

    问题 1 如果输入是包含以下内容的原始类型列 Spark 不会调用 UDFnull inputDF show x null 1 0 inputDF withColumn y udf x Double gt 2 0 apply x will
  • 禁用 jQuery 中的按钮

    我的页面创建多个按钮id rbutton i 下面是我的代码
  • Eclipse 错误:无法确定 /project-path/ 的 URI

    我在 VirtualBox 中的 Ubuntu 12 0 4 上使用 Windows 8 主机运行 Eclipse Luna 每隔一段时间 我就会启动 Ubuntu 并打开 Eclipse 来查找以下内容 我的项目应该列在包资源管理器中 但
  • python的“in”语言构造对于列表来说是线程安全的吗?

    Is obj in a list线程安全的同时a list可能会在不同的线程中修改 这是一个全面但非详尽的示例列表 of list操作以及它们是否是线程安全的 但是我找不到任何参考in语言构造 在 python 实现方面 我使用 CPyth
  • 简单的 html dom 抓取大型 html 文件

    我需要抓取一个大的 html 文件 例如 http www indianrail gov in mail express trn list html 使用简单的 html dom 我从一个简单的脚本开始 它什么也没显示 只是一个空白页 其中
  • 查找 TabStrip 索引

    是否可以在 KendoUI TabStrip 中找到选项卡的索引 我需要找到我选择的选项卡的索引 编号 并且我知道select 返回我当前的选项卡 但我不知道如何将其转换为数字 找到了解决方案 tabstrip data kendoTabS
  • VAO 是否会记住 EBO/IBO(元素或索引)和 VBO?

    我的代码正在正常工作 但这可能是一个巧合 我不想稍后再纠缠于错误 所以我试图尽可能保持它干净 我执行以下操作来初始化网格 生成并绑定 VBO 和缓冲区数据 生成并绑定 IBO 和缓冲区数据 生成并结合 VAO 绑定与之前相同的 VBO 在
  • 如何在Windows中异步打开文件

    有没有办法在 Windows 中异步打开文件 CreateFile API 函数只有 FILE FLAG OVERLAPPED 允许进一步异步读取和写入 尽管如此 文件的打开似乎是同步的 鉴于它必须访问文件系统 并可能执行昂贵的 IO 操作
  • 使用 fscanf 读取双精度

    我想从文本文件中读取双精度值 例如 31 39 9316476397222 116 113516352222 我两种都试过了 没用 我只能读取前几位十进制数字 例如39 93164 但不是 39 9316476397222 有人知道为什么吗
  • 无需光标即可在 Android Sqlite 中访问大型 BLOB

    Android 的光标窗口大小似乎有 1MB 的限制 这限制了从 SQLite 读取 BLOB 的能力 我知道您可能会说我们不应该将 BLOB 存储在数据库中 但根据定义 BLOB 被视为二进制大对象 如果不需要将它们存储在数据库中 则无需