数据库Android知识Android技术知识

Android:SQLite数据存储

2016-12-13  本文已影响314人  Gunther

SQLite数据库的特点

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

创建数据库

  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自然明白)

1. nullColumnHack:如果写null,就无法插入一条空数据(2.3会出异常,4.0之后可以写null)
2. 如果想插入空数据,第二个参数必须写一个列名(任意列)
3. 这个列名是用来拼接sql语句的,如果contentValue为空,则后台不知道表的列名,无法构建sql语句
4. ContentValue:键值对:键对应列明,值对应插入的值
5. 返回值 long id,插入的主键id
  1. update("表名",contentValues(更新列、值),条件,条件值),返回受影响的行数
  2. query("表名", 查询的字段, 条件, 条件值);
上一篇下一篇

猜你喜欢

热点阅读