SQLite Database判断是否存在、新建、删除.....

 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;
}

}

  

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要下载SQLite库的相关文件,包括sqlite3.h、sqlite3.dll和sqlite3.lib,可以按照以下步骤进行: 1. 打开SQLite的官方网站(https://www.sqlite.org/)。 2. 在网站的主页上,点击"Download"(下载)按钮。 3. 在下载页面中,找到相应版本的SQLite库。通常会提供不同的版本,包括预编译好的二进制文件和源代码。 4. 选择适合你系统的版本。如果你使用的是Windows操作系统,通常可以选择一个预编译好的二进制版本。确保选择与你系统架构(32位或64位)相匹配的版本。 5. 下载预编译版本的SQLite库。对于Windows系统,通常会提供一个压缩文件,其中包含sqlite3.h、sqlite3.dll和sqlite3.lib文件。 6. 解压下载的压缩文件。 7. 在解压后的文件夹中,你会找到sqlite3.h文件,该文件是SQLite库的头文件。 8. 在同一文件夹中,你会找到sqlite3.dll文件,该文件是SQLite库的动态链接库文件。你可以将该文件复制到你的项目或应用程序所需的位置。 9. 如果你需要在Visual Studio等IDE中开发应用程序,可以使用sqlite3.lib文件。将该文件添加到你的项目中,以便在编译时链接SQLite库。 10. 现在,你可以在你的项目中包含sqlite3.h头文件,并在编译时链接sqlite3.lib文件,以使用SQLite库的功能。 请注意,这些步骤仅适用于Windows操作系统。在其他操作系统上,可能需要采取不同的步骤或使用不同的文件。建议在下载和使用SQLite库时,参考官方文档和相关资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值