日期:2014-05-16 浏览次数:20355 次
本文译自:http://developer.android.com/training/basics/data-storage/databases.html
把重复的或结构化的数据(如通信录信息)保存到数据库中是很好的想法。本节课假设你熟悉通常的SQL数据库,并帮助你在Android平台上开始使用SQLite数据库。在Android平台上,你需要使用的数据库API包含在android.database.sqlite包中。
定义模式和约束
SQL数据的一个主要原则是模式:数据库是如何组织的一个正式声明。模式被反映在你用于创建数据库的SQL语句中。你可能会发现,它有助于创建伴侣类,即约束(contract)类,这个类使用系统性的和自记录的方式来明确的指定你的模式的布局。
约束(contract)类是一个定义URIs、表名和列名的常量容器。在相同包中的所有类都可以使用这个约束类中的常量。这样就会一处修改,全局有效。
组织约束类的一个好方法是把定义放到类的根层次,以便它对整个数据库有效。
注意:通过实现BaseColumns接口,你的内部类会继承一个叫做_ID的主键,某些Android类(如游标适配器)会希望有这个字段。它不是必须的,但是,这个字段会帮助你的数据库跟Android框架更和谐的工作。
例如,以下代码片段定义一个表的表名和列名:
publicstaticabstractclassFeedEntryimplementsBaseColumns{
public static final String TABLE_NAME = "entry";
public static final String COLUMN_NAME_ENTRY_ID = "entryid";
public static final String COLUMN_NAME_TITLE = "title";
public static final String COLUMN_NAME_SUBTITLE = "subtitle";
...
}
为了防止约束类被意外的实例化,它的构造器是私有的:
// Prevents the FeedReaderContract class from being instantiated.
private FeedReaderContract() {}
使用SQL辅助器来创建数据库
一旦你定义了你的数据库,你就应该实现创建和维护数据库以及表的方法。以下是创建和删除表的典型语句:
privatestaticfinalString
TEXT_TYPE =" TEXT";
private static final