Android SQLite

  • SQLite一款开源的, 轻量级的数据库.
  • 以文本文件的形式存储数据.
  • SQLite支持所有标准的关系型数据库特性.
  • SQLite运行时占用内存非常少(约250 KByte).
  • 使用简单, 无需安装配置.

SQLite数据库存储类型支持TEXT(类似Java中的String), INTEGER(类似Java中的LONG), REAL(类似JAVA中的double).所有其他的类型都在存储前转换成上述类型. 实际上SQLite数据库是无类型检查的.

More information about SQLite can be found on the SQLite website

基本SQL语句

表操作

  • 创建表
CREATE TABLE products (_id INTEGER PRIMARY KEY AUTOINCREMENT, productname TEXT)
  • 删除表
DROP TABLE products

增查改删CRUD

  • 增Create
INSERT INTO products VALUES (NULL, 'apple')
  • 查Retrieve
SELECT * FROM products WHERE productname='apple'
  • 改Update
UPDATE products SET productname='orange' WHERE _id=1
  • 删Delete
DELETE FROM products WHERE productname='apple'

使用SQL Helper操作数据库

我们通过继承SQLiteOpenHelper类来实现我们自己的数据库管理类, 在构造器中要调用父类SQLiteOpenHelper的构造器声明数据库名和当前数据库版本号.

public DatabaseHandler(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

在这个类中有两个需要重写的方法用来创建和更新数据库, 两个方法都接收一个SQLiteDatabase对象作为参数, :

  • onCreate() - 构造数据的方法, 如果数据库已经连接但是还没有创建, 系统框架会调用这个方法. 我们在此处创建数据库表.

  • onUpgrade()- 当已存在的数据库版本号与代码中声明的版本号不同时系统调用此方法升级数据库.(与之类似的还有onDowngrade()方法).

    @Override
public void onCreate(SQLiteDatabase db) {
Log.i(TAG, "handler created");
String sql = "create table " + TABLE_PRODUCTS + "(" +
COL_ID + " integer primary key autoincrement, " +
COL_PRODUCT_NAME + " text );";
db.execSQL(sql);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}

官方建议数据库表中包含_id字段作为主键, 一些Android功能依赖于此字段.

SQLiteOpenHelper类提供getReadableDatabase()getWriteableDatabase()方法来访问数据库对象, 分别是只读和读写模式.

SQLiteDatabase

SQLiteDatabase提供如下方法用于操作数据库:

  • long insert(String table, String nullColumnHack, ContentValues values) 插入
  • int delete(String table, String whereClause, String[] whereArgs) 删除
  • int update(String table, ContentValues values, String whereClause, String[] whereArgs) 更新
  • Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy) 查询
  • void execSQL(String sql) 直接执行sql语句.
  • Cursor rawQuery(String sql, String[] selectionArgs) 直接运行sql查询语句.
  • void close() 释放对象引用.

ContentValues对象可以定义一组键值对. key代表数据库表中的列名, value代表对应列的值.

参数化的查询方式可以避免SQL注入攻击, 同时更具可读性.

insert()代码实例:

// Gets the data repository in write mode
SQLiteDatabase db = mDbHelper.getWritableDatabase(); // Create a new map of values, where column names are the keys
ContentValues values = new ContentValues();
values.put(FeedEntry.COLUMN_NAME_ENTRY_ID, id);
values.put(FeedEntry.COLUMN_NAME_TITLE, title);
values.put(FeedEntry.COLUMN_NAME_CONTENT, content); // Insert the new row, returning the primary key value of the new row
long newRowId;
newRowId = db.insert(
FeedEntry.TABLE_NAME,
FeedEntry.COLUMN_NAME_NULLABLE,
values);

游标Cursor

查询操作返回一个游标对象. Cursor代表一次查询的结果并且指向查询结果中的一行. 这样Android可以有效的缓存查询结果, 因为它不会把所有的结果加载进内存.

  • getCount() 获得结果的数量.
  • moveToFirst() moveToNext() 等方法用于移动游标.
  • isAfterLast() 检验是否游标移动到最后.
  • getString(int columnIndex) 获取当前游标位置的数据, 还可以是getLong()...
  • void close() 游标在使用结束后需要关闭.

示例代码

简单起见, 示例代码中使用直接执行SQL语句的方式进行数据库操作.

public class DBHandler extends SQLiteOpenHelper {

    private static final int DB_VERSION = 1;
private static final String DB_NAME = "products.db";
private static final String TABLE_PRODUCTS = "products";
private static final String COL_ID = "_id";
private static final String COL_PRODUCT_NAME = "productname";
private static final String TAG = "ysz"; public DBHandler(Context context) {
super(context, DB_NAME, null, DB_VERSION);
} @Override
public void onCreate(SQLiteDatabase db) {
String sql = "create table " + TABLE_PRODUCTS + "(" +
COL_ID + " integer primary key autoincrement, " +
COL_PRODUCT_NAME + " text );";
db.execSQL(sql);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
} public void insert(String name) {
SQLiteDatabase db = getWritableDatabase();
for (int i = 1; i < 499; i++) {
db.execSQL("insert into products values (null, ?)", new String[]{name});
}
db.close();
} public void delete(String name) {
SQLiteDatabase db = getWritableDatabase();
db.execSQL("delete from products where productname=?", new String[]{name});
db.close();
} public String getAllProducts() {
StringBuffer buffer = new StringBuffer();
// Select All Query
String selectQuery = "SELECT * FROM " + TABLE_PRODUCTS;
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// looping through all rows and adding to list
if (cursor.moveToFirst()) {
do {
buffer.append(cursor.getString(1));
buffer.append("\n");
} while (cursor.moveToNext());
}
cursor.close();
db.close();
return buffer.toString();
}
}

参考

Android SQLite database and content provider - Tutorial

Android SQLite Database Tutorial

保存到数据库

Saving Data in SQL Databases

Android - SQLite Database Tutorial

Android SQLite 简易指北的更多相关文章

  1. [Android Studio] 2019年Android Studio配置指北

    Android Studio是我学习Android开发路上的第一块绊脚石,新建一个项目,一行代码没动,直接编译不起来,我太难了,所以本文叫指北 本文讲解在9102年如何在国内网络不通畅的情况下流畅的使 ...

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

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

  3. Android Sqlite 数据库版本更新

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

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

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

  5. 基于Android 平台简易即时通讯的研究与设计[转]

    摘要:论文简单介绍Android 平台的特性,主要阐述了基于Android 平台简易即时通讯(IM)的作用和功能以及实现方法.(复杂的通讯如引入视频音频等可以考虑AnyChat SDK~)关键词:An ...

  6. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

  7. Android SQLite总结[转载]

    [转载] :http://blog.163.com/zqy216_2008/blog/static/4119371820119954812509/ 最近在做的项目涉及到了SQLite,大学时没有好好学 ...

  8. Android开发简易教程

    Android开发简易教程 Android 开发因为涉及到代码编辑.UI 布局.打包等工序,有一款好用的IDE非常重要.Google 最早提供了基于 Eclipse 的 ADT 作为开发工具,后来在2 ...

  9. [转] iOS开发者的Weex伪最佳实践指北

    [From] http://www.cocoachina.com/ios/20170601/19404.html 引子 这篇文章是笔者近期关于Weex在iOS端的一些研究和实践心得,和大家一起分享分享 ...

随机推荐

  1. java三大框架介绍

    常听人提起三大框架,关于三大框架,做了如下了解: 三大框架:Struts+Hibernate+Spring java三大框架主要用来做WEN应用. Struts主要负责表示层的显示 Spring利用它 ...

  2. .NET Core 事件总线,分布式事务解决方案:CAP

    背景 相信前面几篇关于微服务的文章也介绍了那么多了,在构建微服务的过程中确实需要这么一个东西,即便不是在构建微服务,那么在构建分布式应用的过程中也会遇到分布式事务的问题,那么 CAP 就是在这样的背景 ...

  3. Android 应用退到后台

    Android 应用退到后台 2016-4-21 10:29:26 Android L moveTaskToBack(boolean nonRoot) 把包含这个Activity的任务转到后台.并不是 ...

  4. 关于MUI集成微信分享遇到的坑

    今天聊一下MUI这个框架吧! 首先,用这个框架也有很长一段时间了,项目不同,涉及到的功能也有不同,之前没有涉及到微信分享相关的内容!今天,遇到了,也解决了,分享出来. 下面是手顺: 1.分享的代码是参 ...

  5. [javascript] postmessage

    摘要 postmessage 作为 html5 跨域传值的解决方法,灰常好用啊..本次用的是页面a 用iframe 嵌入 页面b. 使用方法 postmessage 参数 otherWindow.po ...

  6. [补档]happiness

    happiness 题目 传送门:http://cogs.pro/cogs/problem/problem.php?pid=1873 高一一班的座位表是个n×m的矩阵,经过一个学期的相处,每个同学和前 ...

  7. Hbase集群监控

    Hbase集群监控 Hbase Jmx监控 监控每个regionServer的总请求数,readRequestsCount,writeRequestCount,region分裂,region合并,St ...

  8. 安徽省2016“京胜杯”程序设计大赛_B_阵前第一功

    阵前第一功 Time Limit: 1000 MS Memory Limit: 65536 KB Total Submissions: 63 Accepted: 29 Description A国每个 ...

  9. 蓝桥杯算法训练_2的次幂表示+前缀表达式+Anagrams问题+出现次数最多的整数

    今天做了4个简单的题,题目虽然是简单,但是对于我这样的小白,还是有很多东西需要学习的. 2的次幂表示 上面就是题目,题目说的也很清晰了,接下来就是递归的实现: #include<iostream ...

  10. 【NO.8】jmeter-场景-上传文件-send-a-file

    简要说就3点: POST请求 Request的参数都写在路径内,不写在表单里 上传的文件写在表单里 只要记住以上3点,也就避免了在设计脚本的时候走弯路.下面具体图文并茂地介绍如何使用Jmeter实现上 ...