SQLite 学习

SQLite简介

SQLite是一个小型数据库,它被集成到Android系统中完成数据库部分。它不需要进行配置和管理,可以在Android系统中直接使用。

SQLite使用

1.SQLiteOpenHelper

SQLiteOpenHelper使用一个帮助类,通过继承它并实现onCreate方法和Upgrade方法,来管理我们的数据库。

  • onCreate方法是framework层调用,当你要打开某个数据库,但是这个数据库不存在时,framework就会调用这个方法去创建一个数据库。
  • onUpgrade方法是在对数据库进行更新时调用的,当你的数据库版本增加时,你可以通过调用这个方法修改数据库或者删除数据库然后通过调用onCreate方法重现创建数据库。
    另外SQLiteOpenHelper还提供了getReadableDatabase方法和getWriteableDatabase方法去获取一个SQLDatabase对象。
    上述两方法中都会使用SQLiteDatabase对象作为参数,这个类就代表了数据库。

注意:对于数据库创建的最佳实践是,每个表都建一个类,并且在这个类中定义static的onCreate和onUpgrade方法,这些方法在SQLiteOpenHelper中被调用,这样你的SQLiteOpenHelper实现类就有很好的可读性了,即使你有很多的数据表。

2.SQLiteDatabase

SQLiteDatabase类是整个android数据库的基础类,它提供了对数据库操作的增删改查方法,另外还可以通过execSQL方法来执行SQL语句。
ContentValues是对key/value的一个包装,使用它可以将要插入或者要修改的数据以key/value的形式进行封装,在使用相应增改方法的时候直接使用。

  • rawQuery 是SQLDatabase的方法,他可以使用SQL语句直接查询。
  • query是推荐的查询方法,它的使用类似于Hibernate中的查询,只需要将参数查询条件等一参数的形式提供,就可以得到结果
  • Cursor对象,这个是查询的结果使用它可以遍历整个查询出的数据内容(table)
  • SQLiteBuilder是用来创建查询语句的

3.Cursor

这个类是查询结果的封装,使用他可以很方便的获取数据库查询结果。

  • getCount()返回结果数据的条数
  • moveFirst 将游标指向第一条查询结果
  • moveNext 将游标指向下一条查询结果
  • isAfterLast 检查是否已经到达end
    注意:Cursor在使用完成后需要调用close关闭。(TDOO:如果不关闭怎么办)

4.DAO在Android中的使用

DAO的作用就是对外提供增删改查接口,在他的内部封装了SQLiteDatabase,以及SQLiteOpenHelper,将常用的增删改查以静态方法的形式对外提供。并且还封装了一些对数据进行初步加工的方法。DAO的存在就是将应用层和数据持久层相互隔离,应用层需要操作数据时,只通过DAO来和持久层交互。在持久层的实现中可以引入CursorLoader之类的东西。在Android中的最佳实践是使用ContentProvider来访做DAO与数据层进行交互,因为Android为此提供了安全而完善的机制访问数据层。

SQLite使用注意事项

  • 在对数据库进行操作的时候会访问文件系统,很有可能是耗时操作,因此建议放在异步线程进行数据库操作。
  • 应用创建的数据库的位置为DATA/data/包名/databases/数据库名,其中DATA是Environment.getDataDirectory() 方法返回的路径。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,892评论 25 707
  • 前言 数据库的应用已经深入到生活和工作的方方面面,重要性已无需赘言,而对于移动领域的开发人员来说,SQLite则是...
    lvjsky阅读 708评论 0 1
  • SQLite Design and Concepts API 分为两大类 core API. 基本的SQL操作 e...
    我是花老虎阅读 753评论 0 0
  • 我是南去的车 1 1990年7月,云山风景区因陡降暴雨主峰南坡坍塌,旋即发生巨大的泥石流,浊流滚滚,狂泻而下,中间...
    独行的老雕虫阅读 276评论 2 3
  • 今天我只说了三句话 一句用来向大家喊早 一句用来跟陌生人道谢 一句用来对身边的人说晚安 今天太阳照了我三次 一次我...
    小二不2阅读 177评论 2 1