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)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容

  • SQLite数据存储 SQLite时一款轻量级的关系型数据库,运算速度非常快,支持SQL标准语法,还遵循ACID事...
    狮_子歌歌阅读 312评论 0 1
  • 最近项目需要用到涉及数据库SQLite的知识,真正用的时候才发现自己一点都不熟悉。所以打算将其使用方法总结一下,方...
    朋永阅读 2,104评论 0 1
  • 一位老水手说: 我行船渡舟一辈子 就不明白,到底 是水动还是船动 天上的云儿说 那,是风在动
    乡村诗人阅读 1,229评论 1 10
  • 写东西…大小都是一写!尽管只是叙述而非创作,但依然需要一种把自己置身于父母那种时代的激情,研究和揣摩老一辈当时的思...
    ae6a0a783a82阅读 434评论 0 0
  • 作为程序员,时时刻刻接触着互联网,而上网就像个网络爬虫,从一个网页看到一个链接然后忍不住点进去,再看到一堆连接然后...
    欢醉阅读 471评论 4 4