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,可以起别名),不然拿不到主键值。 -
获取可读数据库、可写数据库的区别
可读的数据库也有可能可以写,可读的数据库在获取实例时有可能拿到上一次可写的数据库
创建数据库
- 定义类继承SQLiteOpenHelper
- 声明构造函数,4个参数
- 重写onCreate()方法
- 重写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("表名",条件,条件值),返回受影响的行数。
- update("表名",contentValues(更新列、值),条件,条件值),返回受影响的行数
- query("表名", 查询的字段, 条件, 条件值);