Android:SQLite数据存储

作者: Gunther | 来源:发表于2016-12-13 11:49 被阅读314次
    • 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("表名", 查询的字段, 条件, 条件值);

    相关文章

      网友评论

        本文标题:Android:SQLite数据存储

        本文链接:https://www.haomeiwen.com/subject/uyovmttx.html