阅读更多

使用数据库

SQlite数据库。

Android数据库的实现峰两个层次。在底层通过C++调用SQlite执行SQL语句,通过JNI向上暴露Java接口。

在框架层,提供Java类库,实现数据库的访问,并控制数据和连接。AndroidJava逻辑层通过数据窗口实现对数据库中数据的读取。

应用查询数据时,Android并不会一次性从数据库取出所有数据,而是构建一个数据窗口来实现动态映射部分数据行,将这些数据行从数据库读取出来并放在缓存在上层对象中,如果应用需要的数据正好在窗口的映射范围内,Java逻辑层会立刻从缓存中读取并返回;没有命中则通过JNI接口去数据库实时读取。

数据行的位置会根据范围不断调整,通过后台线程,异步预先从数据库读取,并更新缓存。

 

数据库的使用

SQliteDatabase表示数据库对象,提供2种模式实现增删改查。

最原始模式

利用SQL语句,调用SQliteDatabase.execSQlSQliteDatabase.rawquery执行。

Android提倡结构化描述数据。使用ContentValue对象。

 

支持预编译:SQliteStatement ssh= db.compileStatementSql

Ssh.execute();

 

支持数据库事物操作。Db.beginTransaction();db.endT ransaction()

 

为了帮助开发者更好的使用SQliteDatabase,提供了SQliteOpenHelper,封装了SQliteDatabase类。开发者通过SQliteOpenHelper.getReadableDataBaseSQliteOpenHelper.getWriteableDataBase获取SQliteDatabase对象。

 

并发问题

 

Android SQlite底层设计中,对文件读写进行加锁。在开发中要保证同时访问SQliteDatabase的仅有一个。

更多相关文章

  1. mybatisplus的坑 insert标签insert into select无参数问题的解决
  2. python起点网月票榜字体反爬案例
  3. 读取android手机流量信息
  4. 《Android开发从零开始》——25.数据存储(4)
  5. Android系统配置数据库注释(settings.db)
  6. Android中不同应用间实现SharedPreferences数据共享
  7. android拍照与读取相册
  8. android图表ichartjs
  9. Android内容提供者源码

随机推荐

  1. Android通过startService实现文件批量下
  2. Android获取系统储存以及内存信息的方法(
  3. Android(安卓)自定义属性时TypedArray的
  4. Android(安卓)SDCard UnMounted 流程分析
  5. Android之 VersionCode,VersionName(1)版本
  6. Android(安卓)开源 日历 Calendar 仿小米
  7. 在Android中创建启动界面
  8. Android(安卓)String.xml中的符号总结
  9. android 不能在子线程中更新ui的讨论和分
  10. Android(安卓)AsyncTask 详细解析