Android网络与数据存储——SQLite

SQLite是一个嵌入式的数据库引擎,专门适用于资源有限的设备(如手机)上适量数据存取。它的特点是:轻量级、独立性、隔离性、跨平台、多语言接口、安全性。

一.创建数据库和表


Android提供了一个管理数据库的工具类SQLiteOpenHelper,用于管理数据库的创建和版本更新,创建SQLiteOpenHelper的子类,并实现它的onCreate()和onUpgrade()方法。通过该子类的getReadableDatabase()、getWriteableDatabase()方法打开数据库,获取对应的SQLiteDatabase对象。

onCreate()方法:用于第一次使用软件时生成数据库表。当调用SQLiteOpenHelper的getReadableDatabase()、getWriteableDatabase()方法获取用于操作数据库的SQLiteDatabase实例时,如果数据库不存在,系统会自动生成一个数据库,接着调用onCreate()方法,该方法在初次生成数据库时才会被调用。重写onCreate()方法时,可以生成数据库表结构。

  • getReadableDatabase()方法先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。
  • getWriteableDatabase()方法以写的方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,如果继续写的话,会出错。

onUpgrade()方法:在数据库版本发生变化时会被调用。

数据库创建好了,那么如何在数据库中创建表呢?

我们可以看到继承SQLiteOpenHelper创建子类时,需要重写onCreate(SQLiteDatabase db)方法,该方法的参数是SQLiteDatabase对象db,db有一个方法execSQL(),将建表的SQL语句传入该方法,即可创建数据表。

例如:

private static final String CREATE_CITY_TABLE = "create table city_table(id Integer primary key autoincrement, city_name text, prov_name text)";

@Override
public void onCreate(SQLiteDatabase db) {    
    db.execSQL(CREATE_CITY_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}

以上代码创建了一个名叫city_table的数据表。

二.增、删、改、查


SQLite数据库的增删改查有两种方法:

  1. 如上面创建数据表那样在db.execSQL()方法中传入SQL语句,对数据库进行增删改查。
  2. 利用Android封装好的insert、update、delete或query语句来操作数据库。

insert

long insert(String table, String nullColumnHack, ContentValues values)

参数说明如下:

  • table:想插入数据的数据表名称。
  • nullColumnHack:强行插入null值的数据列的列名。当values参数为null或不包含任何key-value对时该参数有效。
  • values:代表一行记录的数据。

insert方法插入一行记录使用ContentValues存放,ContentValues类似于Map,提供了put(String key, Xxx value)(其中key是数据列的列名)方法用于存入数据,getAsXxx(String key)方法用于取出数据。

delete

delete(String table, String whereClause, String[] whereArgs)

参数说明如下:

  • table:想删除数据的数据表名称。
  • whereClause:满足该whereClause子句的记录将会被删除。
  • whereArgs:为whereClause子句传入参数。

该方法返回受此delete语句影响的记录的条数。

update

update(String table, ContentValues values, String whereClause, String[] whereArgs)

参数说明如下:

  • table:想更新数据的数据表名称。
  • values:想更新的数据。
  • whereClause:满足该whereClause子句的记录将会被更新。
  • whereArgs:为whereClause子句传入参数。

该方法返回受此update语句影响的记录的条数。

query

Cursor query(boolean distinct, String table, String[] columns, String whereClause, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)

参数说明如下:

  • distinct:是否去重复记录。
  • table:执行查询数据的数据表名称。
  • columns:要查询出来的列名。
  • whereClause:查询条件子句。
  • selectionArgs:为whereClause子句传入参数。
  • groupBy:控制分组。
  • String having:对分组进行过滤。
  • String orderBy:对记录进行排序
  • String limit:进行分页。

该方法返回一个Cursor结果集。

三.事务


SQLiteDatabase有两个方法控制事务:

  • beginTransaction():开始事务,此时db会被锁定。
  • endTransaction():结束事务。

在endTransaction()方法结束事务时,是提交事务还是回滚事务,由是否调用setTransactionSuccessful()方法来设置事务标志来决定。如果在事务执行中调用了该方法设置了事务成功,则提交事务;否则将会回滚事务。

判断当前上下文是否处于事务环境中:inTransaction()

四.优化


  1. 使用原始SQL语句执行效率更高。比如rawQuery()、execSQL()。
  2. 只检查有用的列,有用的行,越少越好。
  3. 是否排序。
  4. 是否创建索引。

五.扩展


  • 对象关系映射——ORM(Object Relational Map)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

SQL*Plus 执行脚本时传递参数(@script_name var1,var2)

      在使用sqlplus执行sql脚本时,经常碰到向脚本传递参数的情形。类似于shell脚本的参数传递,我们同样可以向sql脚本传递参数,其方法是脚本后...

7391
来自专栏Android 研究

Android系统启动——5 zyogte进程(Java篇)

上一篇文章,我们知道在AndroidRuntime.cpp的start()函数里面是调用的Zygoteinit类的main()函数,那我们就继续研究

2392
来自专栏西二旗一哥

iOS - autoreleasepool and @autoreleasepool

+ 在一个自动引用计数的环境中(并不是垃圾回收机制),一个包含了多个对象的 NSAutoreleasePool 对象能够接收 autorelease 消息并且...

1534
来自专栏Janti

spring boot开发笔记——mybatis

  mybatis框架的优点,就不用多说了,今天这边干货主要讲mybatis的逆向工程,以及springboot的集成技巧,和分页的使用

1881
来自专栏有困难要上,没有困难创造困难也要上!

HBase客户端API-表管理

3836
来自专栏Hadoop实操

如何使用Java代码访问HDFS.docx

在开发Hadoop应用时,需要用到hadoop-client API来访问HDFS并进行本地调试。本篇文章则主要讲述如何使用Java代码访问Kerberos和非...

6667
来自专栏mukekeheart的iOS之旅

Android基础总结(6)——内容提供器

  前面学习的数据持久化技术包括文件存储、SharedPreferences存储以及数据库存储技术保存的数据都只能被当前应用程序所访问。虽然文件存储和Share...

4339
来自专栏MasiMaro 的技术博文

windows 安全模型简介

操作系统中有些资源是不能由用户代码直接访问的,比如线程进程,文件等等,这些资源必须由系统级代码由RING3层进入到RING0层操作,并且返回一些标识供用户程序使...

2462
来自专栏Android 研究

APK安装流程详解15——PMS中的新安装流程下(装载)补充

代码位置在PackageManagerService的installPackageLI方法里面会调用到,代码如下: PackageManagerService...

2621
来自专栏菩提树下的杨过

rpc框架之 thrift连接池实现

接前一篇rpc框架之HA/负载均衡构架设计 继续,写了一个简单的thrift 连接池: 先做点准备工作: package yjmyzz; public cla...

6108

扫码关注云+社区

领取腾讯云代金券