- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在我的应用程序中有一个要求,我必须时不时地对数据库执行插入和更新查询。现在,我的问题是应在应用程序内维护缓存,并在特定时间间隔后或可能在 20 个条目后,将缓存提交到数据库中?
如果是这种情况,我应该在哪里维护缓存。应该在应用层面还是在服务层面?
有可能说应用程序突然崩溃,因此缓存中的数据不再存在。
这可能是什么情况。
我在某处读到,每次打开和关闭数据库都是一项开销。注意:我的数据库驻留在 sdcard 中。
谢谢。
最佳答案
我在我的应用程序中有一个要求,我必须时不时地对数据库执行插入和更新查询。现在,我的问题是应在应用程序内维护缓存,并在特定时间间隔后或可能在 20 个条目后,将缓存提交到数据库中?
SQLite 中的插入操作相当快。确保在 finally block 中关闭数据库以避免数据库处于打开状态。这可以阻止进一步的插入。尽可能使用批量插入,它们要快得多。 See here
如果是这种情况,我应该在哪里维护缓存。应该在应用层还是服务层?
服务也来自应用层 :) 。有可能在服务中维护缓存并使服务在单独的进程中运行。 See here.
有可能说应用程序突然崩溃,因此缓存中的数据不再存在。
剩下的唯一选择是,要么在其他进程中维护缓存(随时可能再次崩溃),要么在磁盘上维护它,可能是内部存储。在内部存储上维护缓存与写入 sqlite 一样好或坏。
这可能是什么情况。
你实现缓存或者不实现。
我在某处读到,每次打开和关闭数据库都是一项开销。注意:我的数据库驻留在 sdcard 中。
据我所知,打开一个 SQLite 相当于打开一个文件(虽然速度稍慢),但无法与打开 Oracle 数据库相提并论。所以大多数时候打开数据库是负担得起的,但是批处理插入以提高性能永远不会受到伤害;)
关于android - 什么时候将缓存数据提交到android中的数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19698995/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!