可以将dictionary.db文件复制到Eclipse Android工程中的res\raw目录中,如图1所示。所有在res\raw目录中的文件不会被压缩,这样可以直接提取该目录中的文件。
使用openDatabase方法来打开数据库文件,如果该文件不存在,系统会自动创建/sdcard/dictionary目录,并将res\raw目录中的 dictionary.db文件复制到/sdcard/dictionary目录中。openDatabase方法的实现代码如下:
代码
private SQLiteDatabase openDatabase()
{
try
{
// 获得dictionary.db文件的绝对路径
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
File dir = new File(DATABASE_PATH);
// 如果/sdcard/dictionary目录中存在,创建这个目录
if (!dir.exists())
dir.mkdir();
// 如果在/sdcard/dictionary目录中不存在
// dictionary.db文件,则从res\raw目录中复制这个文件到
// SD卡的目录(/sdcard/dictionary)
if (!(new File(databaseFilename)).exists())
{
// 获得封装dictionary.db文件的InputStream对象
InputStream is = getResources().openRawResource(R.raw.dictionary);
FileOutputStream fos = new FileOutputStream(databaseFilename);
byte[] buffer = new byte[8192];
int count = 0;
// 开始复制dictionary.db文件
while ((count = is.read(buffer)) > 0)
{
fos.write(buffer, 0, count);
}
fos.close();
is.close();
}
// 打开/sdcard/dictionary目录中的dictionary.db文件
SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
databaseFilename, null);
return database;
}
catch (Exception e)
{
}
return null;
}
在openDatabase方法中使用了几个常量,这些常量是在程序的主类(Main)中定义的,代码如下:
代码
public class Main extends Activity implements OnClickListener, TextWatcher
{
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath()
+ "/dictionary";
private final String DATABASE_FILENAME = "dictionary.db";
}
分享到:
相关推荐
本文讲解了如何将SQLite数据库(dictionary.db文件)与apk文件一起发布。这个过程可以将dictionary.db文件复制到Eclipse Android工程中的res\raw目录中,从而在apk文件中包含数据库文件。 知识点1:Android中的资源...
功能:通过批量读取多个excel文件,将每个excel文件创建为sqlite数据库文件中的一个表格,最终形成包含这些excel文件内容的.db数据库文件。 用法:将压缩包内的.exe/.dll文件放在同一文件夹内,双击运行文件内的...
Android 实验报告的主要目的是熟悉 Android 平台的文件操作、掌握 Android SQLite 数据库的设计和应用、熟悉 XML 和 JSON 文件的读取。通过本实验,用户可以掌握 Android 平台的基本操作和数据库应用。 二、实验...
标题中的"sqlitedb sms.db"表明我们关注的是一个SQLite数据库文件,具体为"sms.db",这个数据库可能被用于存储短信数据。SQLite是一个轻量级的、自包含的、无服务器的SQL数据库引擎,广泛应用于移动设备和嵌入式系统...
本教程将围绕“安卓SQLite数据库相关-android读取本地.db文件实现不变数据本地化”这一主题,探讨如何在Android应用中读取和使用本地SQLite数据库文件,以实现数据的本地化存储。 首先,要在Android应用中使用...
SQLite数据库文件(如`demo.db3`)通常是一个独立的文件,可以直接在文件系统中创建、打开和修改。这使得SQLite非常方便,因为它不需要单独的数据库服务器进程。 在PHP中,你可以使用PDO提供的各种方法进行更复杂的...
SQLite.Interop.dll 32和64位文件,配合SQLite Expert Professional 4.2可以打开加密数据库。 将SQLite.Interop.dll拷贝到SQLite Expert安装路径,然后打开SQLite Expert,Tools --> Options --> SQLite Library中...
在Java编程中,读取本地SQLite数据库(.db文件)是一项常见的任务,特别是在移动应用开发或者需要离线存储数据的场景下。SQLite是一种轻量级的、开源的关系型数据库,它不需要单独的服务器进程,可以直接在应用程序...
SQLite.Interop.dll 文件是 SQLite 数据库引擎在 .NET 环境中的交互组件,它提供了与 SQLite 数据库进行通信和操作的接口。SQLite 是一个轻量级的、开源的、自包含的关系型数据库管理系统,广泛应用于桌面应用、移动...
SQLite.Interop.dll for sqlite expert professional 4.2 用与SQLite Expert打开本地已加密的数据库的插件。适用32位和64位。 1.直接将下载的文件复制到SQLite Expert安装路径(如:c:\Program Files (x86)\SQLite ...
总结来说,"万年历数据库.db"是一个包含了广泛日历信息的SQLite数据库文件,它的结构和内容设计使得快速访问和处理大量日历数据成为可能。无论是开发日历应用还是提供相关服务,此类数据库都是不可或缺的基础资源。...
这里的path为指定到SQLite数据库文件的路径,例如: jdbc:sqlite://dirA/dirB/dbfile jdbc:sqlite://DRIVE:/dirA/dirB/dbfile jdbc:sqlite://COMPUTERNAME/shareA/dirB/dbfile 三、下面是使用SQLite的两段代码以...
4. 数据导入导出:可以将数据库文件导出为多种格式(如CSV、XML),或者导入其他数据库文件。 通过熟练掌握SqliteStudio的使用,开发者可以更好地调试和优化Android应用中的SQLite数据库,提升应用的数据处理效率。...
SQLite.Interop.dll for sqlite expert professional 4.2 用与SQLite Expert打开本地已加密的数据库的插件。1.将SQLite.Interop.dll x86拷贝到SQLite Expert安装路径(如:x:\Program Files (x86)\SQLite Expert\...
这意味着你的可执行文件将包含SQLite3的功能,无需在运行时依赖`sqlite3.dll`。然而,静态链接可能导致生成的可执行文件较大。 SQLite3的主要特点包括: 1. **零配置**:无需安装,只需要拷贝相关库文件到项目目录...
历史上的今天sqlite数据库
总的来说,SQLite.Interop.dll在.NET开发中扮演着关键角色,确保其与应用程序和SQLite数据库文件的兼容性是解决连接问题的关键。在遇到“file not a database”的错误时,除了检查文件本身,还应考虑升级或替换DLL...
string connectionString = "Data Source=你的数据库文件路径;Version=3"; SQLiteConnection conn = new SQLiteConnection(connectionString); conn.Open(); ``` 3. **执行SQL查询** 创建一个SQLiteCommand...
下面将详细介绍如何在Unity中创建和使用SQLite数据库文件,并探讨一些相关的知识点。 首先,Unity不内置对SQLite的直接支持,但我们可以借助第三方插件来实现这一功能。在提供的压缩包文件`Plugins`中,可能就包含...
SQLiteSpy是一款广受欢迎的.db...而World.db3数据库文件则为我们提供了一个实践和学习SQLite数据库的实例。通过结合使用SQLiteSpy和提供的数据库文件,我们可以深入学习SQLite数据库的使用和管理,提升数据库技术能力。