Android SQLite使用
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使用的更多相关文章
- Android SQLite 通配符查询找不到参数问题
使用Android SQLite中SQLiteDatabase类的query方法查询时,如果where中包含通配符,则参数会无法设置,如类似下面的方法查询时 SQLiteDatabase db = d ...
- Android+Sqlite 实现古诗阅读应用(三)
往期传送门: Android+Sqlite 实现古诗阅读应用(一) Android+Sqlite 实现古诗阅读应用(二) 加入截图分享的功能. 很多应用都有分享的功能,我也想在我的古诗App里加入这个 ...
- Android+Sqlite 实现古诗阅读应用(二)
传送门:Android+Sqlite 实现古诗阅读应用(一) Hi,又回来了,最近接到很多热情洋溢的小伙伴们的来信,吼开心哈,我会继续努力的=-=! 上回的东西我们做到了有个textview能随机选择 ...
- Android Sqlite 数据库版本更新
Android Sqlite 数据库版本更新 http://87426628.blog.163.com/blog/static/6069361820131069485844/ 1.自己写一个类继承 ...
- Android SQLite总结(一) (转)
Android SQLite总结(一) 郑海波 2012-08-21 转载请声明:http://blog.csdn.net/nuptboyzhb/article/details/7891887 前言 ...
- android SQLite使用SQLiteOpenHelper类对数据库进行操作
android SQLite使用SQLiteOpenHelper类对数据库进行操作 原文: http://byandby.iteye.com/blog/835580
- Android sqlite管理数据库基本用法
Android操作系统中内置了sqlite数据库(有关sqlite数据库详细介绍见:http://zh.wikipedia.org/wiki/SQLite),而sqllite本身是一个很小型的数据库, ...
- Android SQLite 数据库详细介绍
Android SQLite 数据库详细介绍 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用 ...
- Android Sqlite 导入CSV文件 .
http://blog.csdn.net/johnnycode/article/details/7413111 今天遇到 Oracle 导出的12万条CSV格式数据导入 Android Sqlite ...
- Android sqlite数据库存取图片信息
Android sqlite数据库存取图片信息 存储图片:bitmap private byte[] getIconData(Bitmap bitmap){ int size = bitmap.get ...
随机推荐
- [CodeForces954D]Fight Against Traffic(最短路)
Description 题目链接 Solution 从起点和终点分别做一次最短路并记录结果 枚举每一条可能的边判断 Code #include <cstdio> #include < ...
- 变量存储类型(auto static extern)
auto 动态存储类型变量(函数内部变量存储默认为 auto型) auto只用于函数内部定义,单片机在执行这个函数时为它分配内存地址,当函数执行完毕返回后,auto变量会被销毁,再次进入这个函数时,它 ...
- Mac 小技巧
本文的大部分技巧来自于池建强老师的<MacTalk.人生元编程>,感谢他的辛苦付出,本文多系整理而已. 终端输入说英语 说英语时我们当然希望有标准发音.在Mac中不需要字典,直接在终端里输 ...
- ICG-智能代码生成器.(权限控制.融入平台).(表单引擎).(最低兼容IE8)
请下拉滚动条... 代码生成器.附带客户端代码 个人平台:www.10086bank.com 界面: 1--首先是server制作界面(BS结构).直接上图: 2--点击提交生成一下文件: 各个代 ...
- DOS程序员手册(十一)
560页 版本5中新增加的子功能05h支持程序截获MS-DOS EXEC调用,并实 现自我装载.该子功能能实现内存的修补,如设置装载程序能接收的版本号 (通过SETVER设置的版本号)以及实现对装载程 ...
- USACO Section2.3 Zero Sum 解题报告 【icedream61】
zerosum解题报告----------------------------------------------------------------------------------------- ...
- USACO刷题之路,开始了
几天前,重新开始刷题了. 重新刷题有几个原因: 1.曾经的OI经历,如今除了悟性高些.知识多些,大多已经遗忘.不希望真的让之前的OI水平就这么丢了. 2.越来越觉得,刷题真的是一件很开心的事情.大学中 ...
- 基类VS接口
该篇引用 CLR via C# 中的13.11节. 应该设计基类还是接口,这个问题不能一概而论,下面提供一些指导性原则: 1. IS_A关系(指属于,例如汽车属于交通工具) vs CAN_DO关系(指 ...
- CandyCrush 糖果传奇
1.unity自带触发事件 unity的每一个Collider对象都有类似OnMouseDown.OnMouseOver等事件.此事件是存在于MonoBehaviour脚本里的,而MonoBehavi ...
- NGUI-Tweens
Tweens(补间动画) 补间动画有很多种: 这里以Tween Height为例: 项目层次: btn为一个按钮,group为一组图片精灵,预览图如下: 第一步:先为每个item附加一个Tween H ...