1. 介绍

SQLite是一款轻型的数据库, 是遵守ACID的关系型数据库管理系统, Android系统已经在框架中适配接口供用户使用.

2. 数据类型

SQLite采用的是动态数据类型, 会根据存入值自动判断.
SQLite具有以下五种常用的数据类型:

存储类 描述
NULL NULL 值
INTEGER 带符号的整数,根据值的大小存储在 1、2、3、4、6 或 8 字节中
REAL 浮点值,存储为 8 字节的 IEEE 浮点数字
TEXT 文本字符串,使用数据库编码(UTF-8、UTF-16BE 或 UTF-16LE)存储
BLOB blob 数据,完全根据它的输入存储

详细信息参考<SQLite 数据类型>

3. 基本使用

在Android中使用SQLite涉及到下面三个类

 - SQLiteOpenHelper: 抽象类. 我们通过继承该类, 然后重写数据库创建以及更新的方法. 我们还可以通过该类的对象获得数据库实例, 或者关闭数据库.
- SQLiteDatabase: 数据库访问类. 我们可以通过该类的对象来对数据库做一些增删改查的操作.
- Cursor: 游标. 有点类似于JDBC里的resultset, 结果集. 可以简单理解为指向数据库中某 一个记录的指针.

2.1 SQLiteOpenHelper

SQliteOpenHelper是一个抽象类, 用来管理数据库的创建和版本的管理

常用方法有:

SQLiteDatabase getReadableDatabase()   :  得到可读的数据库, 返回SQLiteDatabase对象
SQLiteDatabase getWritableDatabase() : 得到一个可写的数据库, 返回SQLiteDataba
void onCreate(SQLiteDatabase) : 创建一个表, 当数据库第一次被建立的时候被执行
void onOpen(SQLiteDatabase) : 打开数据库, 当数据库被打开的时候被执行
void onUpgrade(SQLiteDatabase,int,int) : 当数据库需要被更新的时候执行
void close() : 关闭数据库

我们我们实行一个类(Like DBHelper)来继承SQliteOpenHelper, 同时实现onCreate和onUpgrade方法.
然后创建DBHelper实例, 通过getReadableDatabase()/getWritableDatabase()来获取数据库实例, 随后即可对数据库进行操作

2.2 SQLiteDatabase

SQLiteDatabase是一个数据库对象, 它提供了丰富的方法

/* 静态方法, 打开或创建数据库 */
SQLiteDatabase openOrCreateDatabase(String path, SQLiteDatabase.CursorFactory factory);
/* 插入记录 */

long insert(String table, String nullColumnHack, ContentValues values);
/* 删除记录 */
int delete(String table, String whereClause, String[] whereArgs);

/* 查询记录 */
Cursor query(boolean distinct, String table, String[] columns,
String selection, String[] selectionArgs, String groupBy,
String having, String orderBy, String limit);
/* 更新记录 */
int update(String table, ContentValues values, String whereClause, String[] whereArgs)
/* 执行SQL语句 */
void execSQL (String sql)

更多方法请参考<SQLiteDataBase的一些方法整理>

2.3 Cursor

Cursor 是每行记录的集合, 在使用时必须知道每一列的名称和数据类型
常用方法如下:

/* 关闭游标,释放资源 */
void close()
/* 在缓冲区中检索请求的列的文本,将将其存储 */
void copyStringToBuffer(int columnIndex, CharArrayBuffer buffer)
/* 返回所有列的总数 */
int getColumnCount()
/* 返回指定列的名称, 不存在返回-1 */
int getColumnIndex(String columnName)
/* 从零开始返回指定列名称, 不存在抛出IllegalArgumentException异常 */
int getColumnIndexOrThrow(String columnName)
/* 从给定的索引返回列名 */
String getColumnName(int columnIndex)
/* 返回一个字符串数组的列名 */
String[] getColumnNames()
/* 返回Cursor中的行数 */
int getCount()
/* 移动光标到第一行 */
boolean moveToFirst()
/* 移动光标到最后一行 */
boolean moveToLast()
/* 移动光标到下一行 */
boolean moveToNext()
/* 移动光标到一个绝对的位置 */
boolean moveToPosition(int position)
/* 移动光标到上一行 */
boolean moveToPrevious()

参考:
<SQLite教程>
<Android操作SQLite基本用法>
<Android数据存储与访问之-初见SQLite数据库>
<Android数据库储方式(一)-SQLite的基本操作>

Android SQLite使用的更多相关文章

  1. Android SQLite 通配符查询找不到参数问题

    使用Android SQLite中SQLiteDatabase类的query方法查询时,如果where中包含通配符,则参数会无法设置,如类似下面的方法查询时 SQLiteDatabase db = d ...

  2. Android+Sqlite 实现古诗阅读应用(三)

    往期传送门: Android+Sqlite 实现古诗阅读应用(一) Android+Sqlite 实现古诗阅读应用(二) 加入截图分享的功能. 很多应用都有分享的功能,我也想在我的古诗App里加入这个 ...

  3. Android+Sqlite 实现古诗阅读应用(二)

    传送门:Android+Sqlite 实现古诗阅读应用(一) Hi,又回来了,最近接到很多热情洋溢的小伙伴们的来信,吼开心哈,我会继续努力的=-=! 上回的东西我们做到了有个textview能随机选择 ...

  4. Android Sqlite 数据库版本更新

      Android Sqlite 数据库版本更新 http://87426628.blog.163.com/blog/static/6069361820131069485844/ 1.自己写一个类继承 ...

  5. Android SQLite总结(一) (转)

    Android SQLite总结(一)  郑海波 2012-08-21 转载请声明:http://blog.csdn.net/nuptboyzhb/article/details/7891887 前言 ...

  6. android SQLite使用SQLiteOpenHelper类对数据库进行操作

    android SQLite使用SQLiteOpenHelper类对数据库进行操作 原文: http://byandby.iteye.com/blog/835580

  7. Android sqlite管理数据库基本用法

    Android操作系统中内置了sqlite数据库(有关sqlite数据库详细介绍见:http://zh.wikipedia.org/wiki/SQLite),而sqllite本身是一个很小型的数据库, ...

  8. Android SQLite 数据库详细介绍

    Android SQLite 数据库详细介绍 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用 ...

  9. Android Sqlite 导入CSV文件 .

    http://blog.csdn.net/johnnycode/article/details/7413111 今天遇到 Oracle 导出的12万条CSV格式数据导入 Android Sqlite ...

  10. Android sqlite数据库存取图片信息

    Android sqlite数据库存取图片信息 存储图片:bitmap private byte[] getIconData(Bitmap bitmap){ int size = bitmap.get ...

随机推荐

  1. 20,Django contenttypes 应用

    contenttypes 是Django内置的一个应用,可以追踪项目中所有app和model的对应关系,并记录在ContentType表中. 1.创建一个项目 2.数据库迁移,生成默认表. 3.存着所 ...

  2. cocos2d-x 3.0环境配置(转)

    cocos2d-x 3.0发布有一段时间了,作为一个初学者,我一直觉得cocos2d-x很坑.每个比较大的版本变动,都会有不一样的项目创建方式,每次的跨度都挺大…… 但是凭心而论,3.0RC版本开始 ...

  3. PowerCmd

    今天在手机上看慕课网,看到一个好玩的东西.Powercmd. 一开始的感觉是,妈的,我会cmd命令,为什么要用你的cmd? 后来,用了之后,感觉,嗯,还是Powercmd好用.功能强大. 我们来看看它 ...

  4. spring里面的context:component-scan

    原文:http://jinnianshilongnian.iteye.com/blog/1762632 component-scan的作用的自动扫描,把扫描到加了注解Java文件都注册成bean &l ...

  5. js对数组去重的完整版

    数组去重是很常见的一个需求,而各种各样的姿势也很多,常见的如indexOf,或者hash,但是他们还是有缺陷,这里我查了一些资料做补充. 一般方式 //一般方法->使用indexOf Array ...

  6. ADB命令总结(1)

    今日继续学习ADB,使用真机来操作,因此把所用到的命令总结如下: 一,模拟按HOME键 adb shell input keyevent KEYCODE_HOME 二,滑动手机屏幕 从(x1,y1)滑 ...

  7. 【视觉SLAM14讲】ch3课后题答案

    1.验证旋转矩阵是正交矩阵 感觉下面这篇博客写的不错 http://www.cnblogs.com/caster99/p/4703033.html 总结一下:旋转矩阵是一个完美的矩阵——正交矩阵.①行 ...

  8. 1155 Heap Paths (30 分)(堆+dfs遍历)

    比较简单的一题 遍历左右的时候注意一下 #include<bits/stdc++.h> using namespace std; ; ]; ; vector<int>t; ve ...

  9. NodeJs03 express框架 Todo商城

    前言 由于NodeJs本身的异步非阻塞特性和对http的天然支持,所以使用NodeJs编写高性能,可伸缩的Web服务器非常简单.开发完整的Web服务器还需要路由,错误处理,请求拦截,请求和响应的解析, ...

  10. 团队项目-任务分解[Alpha0]

    团队项目-任务分解[Alpha0] 标签(空格分隔): 团队博客 适用范围: 本文档 适用对象 团队全体成员 适用时间 alpha阶段第一周计划 10.24-10.28 适用内容 目标.分工.时长估计 ...