Android:SQLite数据存储

  • 2016年12月8日,Google中国开发者大会在京举行,同时正式上线了Google中国开发者网站Google Developers,查看官方学习资源再也不用爬梯子了

SQLite数据库的特点

SQLite,是一款轻量型的数据库,是遵守ACID(原子性、一致性、隔离性、持久性)的关联式数据库管理系统,多用于嵌入式开发中。
Android平台中嵌入了一个关系型数据库SQLite,和其他数据库不同的是SQLite存储数据时不区分类型,例如一个字段声明为Integer类型,我们也可以将一个字符串存入,一个字段声明为布尔型,我们也可以存入浮点数。
除非是主键被定义为Integer,这时只能存储64位整数,SQLite,无需安装,是Android平台自带的一个数据库。

  • 创建数据库的表时可以不指定数据类型,例如:

    CREATE TABLE person(id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20))
    
  • SQLite支持大部分标准SQL语句,增删改查语句都是通用的,分页查询语句和MySQL相同

    SELECT * FROM person LIMIT 20 OFFSET 10
    SELECT * FROM person LIMIT 10,20
    
  • SQLite与MySql的不同之处
    主键自增长:SQLite是autoincrement,MySql是auto_increment
    主键:SQLite主键一般定义为_id,在做查询时要求主键列名必须是_id(本身不是_id,可以起别名),不然拿不到主键值。

  • 获取可读数据库、可写数据库的区别
    可读的数据库也有可能可以写,可读的数据库在获取实例时有可能拿到上一次可写的数据库

创建数据库

  1. 定义类继承SQLiteOpenHelper
  2. 声明构造函数,4个参数
  3. 重写onCreate()方法
  4. 重写upGrade()方法
    public class PersonOpenHelper extends SQLiteOpenHelper {
        public PersonOpenHelper(Context context, String name, CursorFactory factory, int version) {
            super(context, name, factory, version);
                  }
                public void onCreate(SQLiteDatabase db) {
                // 数据库第一次被创建的时候执行如下sql语句创建一个person表
                db.execSQL("create table person(id integer primary key autoincrement, name varchar(20), phone varchar(20), money integer(20),age integer(10));");
                }
                public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
                // 数据库的版本更新的时候执行
                if (oldVersion == 1 && newVersion == 2) {
                    db.execSQL("alter table person add column balance integer");
                }
                }
   
      }

创建一个PersonOpenHelper类来测试上面的代码

public class PersonOpenHelperTest extends AndroidTestCase {
public SQLiteDatabase getDataBase(){
    PersonOpenHelper helper = new PersonOpenHelper(getContext(), "person.db", null, 1);
    SQLiteDatabase writableDatabase = helper.getWritableDatabase();
    return writableDatabase;
    }
}

执行完上面代码后,通过DDMS,查看/data/data/com.包名.sqlite/databases目录,发现产生了两个文件,person.db和person.db-journal。其中第一个文件就是我们的数据库文件。

第一次操作数据库时,person.db-journal文件会被自动创建,该文件是sqlite的一个临时的日志文件,主要用于sqlite数据库的事务回滚操作了。 但是Android系统中将该文件永久的保存在磁盘中,不会被自动清除的,如果没有操作异常或者不需要事务回滚时,此文件的大小为0。这种机制避免了每次生成和删除person.db-journal文件的开销。

在测试类中创建该类对象,调用getWritableDatabase()或者getReadableDatabase():如果数据库不存在,创建数据库文件,执行onCreate()方法,并获取数据库对象。如果数据库存在,版本号没有发生改变,直接获取数据库对象。如果数据库存在,版本号提升,先执行onUpgrade()方法,再获取数据库对象。

数据库并不是初始化MyHelper时创建。如果版本号降低,应用降级。并且不重写onDowngrade,就会调用父类的onDowngrade方法,抛出异常。一般不重写,没这个需求。

SQLiteDataBase自带的增删改查

SQLiteDatabase专门提供了对应于添加(insert)、删除(delete)、更新(update)、查询(query)的操作方法。

这些方法封装了部分SQL语句,通过参数进行拼接,这些方法实际上是给那些不太了解SQL语法的开发者使用的。对于熟悉SQL语法的程序员而言,直接使用execSQL()和rawQuery()方法执行SQL语句就能完成数据的添加、删除、更新、查询操作。

这四个方法主要是在使用内容提供者时使用,因为ContentProvider中提供的增删改查方法,与这一套一样,方便调用传参。(等学完ContentProvider自然明白)

  • insert("表名",nullColumnHack,"",contentValue)
1. nullColumnHack:如果写null,就无法插入一条空数据(2.3会出异常,4.0之后可以写null)
2. 如果想插入空数据,第二个参数必须写一个列名(任意列)
3. 这个列名是用来拼接sql语句的,如果contentValue为空,则后台不知道表的列名,无法构建sql语句
4. ContentValue:键值对:键对应列明,值对应插入的值
5. 返回值 long id,插入的主键id
  • delete("表名",条件,条件值),返回受影响的行数。
  1. update("表名",contentValues(更新列、值),条件,条件值),返回受影响的行数
  2. query("表名", 查询的字段, 条件, 条件值);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,928评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,748评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,282评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,065评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,101评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,855评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,521评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,414评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,931评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,053评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,191评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,873评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,529评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,074评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,188评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,491评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,173评论 2 357

推荐阅读更多精彩内容