2008年10月27日星期一

SQLite用于Android

下面是个人搜集的一些信息,关于Android平台使用SQLite的情况。

使用SQLite数据库

Android支持SQLite数据库系统并开放数据库管理函数,这使你可以将复杂的数据集合储存到有用的对象中。例如,Android定义了一种由字符串型姓名、字符串型地址、数字型电话号码、一个位图图像和多种其它个人信息描述字段组成的通讯录数据类型。使用Context.createDatabase()和Context.openDatabase()创建读写数据库和适当的读写数据(注意:位图这样的文件数据与本地文件路径一样,以文件路径字符串值形式存放在数据库中)

Android整合sqlite3数据库工具,允许你在SQLite数据库中浏览表内容、运行SQL命令并执行其它有用的函数。

SQLite及其它的所有的数据库,被储存于/data/data//databases

创建多少表、包含多少字段、如何连接,已经超越了这篇文档的讨论范围,但是Android没有施加任何越过SQLite concepts的限制。我们极力推荐包含一个如唯一ID的自增字段以快速查找记录。对于私有数据,这并不需要。但是如果你使用一个内容提供器,你必须包括一个类似唯一ID的字段。请参考NotePad示例程序中的示例类NotePadProvider.java,那是一个创建和组装新数据库的例子。任何数据库可以凭借数据库名被该软件中的任何一个类访问,但不能在该软件范围外访问。

Android 数据库为何采用sqlite数据库?
一、手机内存有限,采用对时间空间要求越低的越好。sqlite是一个轻量级别的数据库,在一些简单语句的处理性能上比mysql和postgresql都要快。它的标识就是一只羽毛,做一些小东西,用它处理再好不过了。
二、开源性。没有其他依赖,直接加压就可以使用,并且源代码是开放的,95%有较好的注释。android本身就是开源的东西,当然选择开源的数据库啦。

Android SQLite Database

本打算封装SQLite的,但是,发现实际上Android已经封装了一层,尤其是数据的增、删、查、改上,更是如此,所以,我后来只封装了一个连接层,负责打开、建立数据库,并返回一个SQLite的实例用来完成增、删、插、改等操作。

//----------- DBHelper -------------

package utility.db;

import java.io.FileNotFoundException;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;

public class DBHelper
{
private SQLiteDatabase db = null;

private Context ctx = null;

public DBHelper( Context ctx )
{
this.ctx = ctx;
}

/**
* 判断数据库是否存在
*
* @param dbName
* 数据库名称
* @return true存在 false不存在
*/
public boolean exist( String dbName )
{
Log.log("called fun : exist()");
boolean flag = false;
try
{
db = ctx.openDatabase(dbName, null);
Log.log("database/"+dbName+" exist");
flag = true;
}
catch (FileNotFoundException e)
{
flag = false;
Log.log("database/"+dbName+" not exist");
}
finally
{
if (db != null)
db.close();
db = null;
}
return flag;
}

/**
* 打开数据库
*
* @param dbName
* 数据库名称
* @return true 打开成功 false打开失败
*/
public boolean openDatabase( String dbName , boolean created )
{
return openDatabase(dbName, null, created);
}

/**
* 打开数据库
*
* @param dbName
* 数据库名称
* @param factory
* @return true 打开成功 false打开失败
*/
public boolean openDatabase( String dbName , CursorFactory factory ,
boolean created )
{
Log.log("called fun : openDatabase()");
Log.log("called fun : if not exist then created "+dbName+" ? : "+created);
boolean flag = false;
if(exist(dbName))
{
try
{
db = ctx.openDatabase(dbName, factory);
Log.log("database/"+dbName+" is opened");
flag = true;
}
catch (FileNotFoundException e)
{
Log.log("database/"+dbName+" is not opened");
flag = false;
}
}
else
{
if(created)
{
flag = createDatabase(dbName, 1, 0, factory);
}
else
{
flag = false;
}
}
return flag;

}

/**
* 创建数据库
*
* @param dbName
* 数据库名称
* @param version
* 数据库版本
* @param mode
* 模式
* @param factory
* @return true 建立成功 false 建立失败
*/
public boolean createDatabase( String dbName , int version , int mode ,
CursorFactory factory )
{
Log.log("called fun : createDatabase()");
boolean flag = false;
try
{
db = ctx.createDatabase(dbName, version, mode, factory);
Log.log("database/"+dbName+" is created successfully!");
flag = true;
}
catch (FileNotFoundException e)
{
Log.log("database/"+dbName+" can't be created");
flag = true;
}
return flag;
}

/**
* 建立数据库
*
* @param dbName
* 数据库名称
* @return true 打开成功 false 打开失败
*/
public boolean createDatabase( String dbName )
{
return createDatabase(dbName);
}

/**
* 关闭数据库
*
*/
public void closeDatabase()
{
Log.log("close database");
if (db != null)
db.close();
db = null;
ctx = null;
}
/**
* 删除表
* @param tableName 表名
* @return 成功则返回 表名 失败则返回null
*/
public String dropTable( String tableName )
{
Log.log("called fun dropTable()");
if (tableName == null)
{
Log.log("table name is error! "+tableName+" is null !");
return null;
}
String DROP_TABLE = "DROP TABLE IF EXISTS " + tableName;
db.execSQL(DROP_TABLE);
Log.log("table/"+tableName+" is dropped successfully");
return tableName;
}
/**
* 取得数据库实例
* @return 返回数据库实例
*/
public SQLiteDatabase getDBInstance()
{
return db;
}
public boolean execSQL(String SQL)
{
boolean flag = false;
Log.log("called fun execSQL()");
Log.log("SQL:"+SQL);
try
{
db.execSQL(SQL);
Log.log("sql exec successfully!");
flag = true;
}
catch(Exception e)
{
Log.log("sql exec not successfully!");
flag = false;
}
return flag;
}

}

Android平台是一个新开发平台,但由于是Java的接口,因此应用起来应该说没有什么先天障碍,但是,他的XML界面配置总让我觉得匪夷所思,感觉不是想象中那样简单使用的方法,所以还需要研究~

没有评论: