鸿蒙应用本地数据库导出与查看指南

鸿蒙应用本地数据库导出与查看指南

一、导出方法(推荐3种)

方法1:DevEco Studio可视化导出(开发调试首选)

  1. 在IDE右侧打开 Device File Browser

  2. 导航至数据库路径:/data/storage/el2/database/entry/rdb/

  3. 同时选中以下三个文件:

    • 数据库名.db
    • 数据库名.db-wal
    • 数据库名.db-shm
  4. 右键选择 Save As → 保存到本地文件夹

方法2:使用hdc命令行工具

bash

perl 复制代码
# 连接设备
hdc shell

# 查找数据库路径
find /data -name "数据库名.db"

# 退出shell后导出文件
hdc file recv /沙箱路径/数据库名.db 本地路径
hdc file recv /沙箱路径/数据库名.db-wal 本地路径
hdc file recv /沙箱路径/数据库名.db-shm 本地路径

方法3:代码实现导出(应用内功能)

typescript

javascript 复制代码
import picker from '@ohos.file.picker';

// 备份数据库
async backupDatabase() {
    const dbBackupPath = this.context.databaseDir + '/backup.db';
    await this.rdbStore.backup(dbBackupPath);
    return dbBackupPath;
}

// 导出到用户设备
async exportDatabase() {
    const backupPath = await this.backupDatabase();
    const filePicker = new picker.DocumentViewPicker();
    const targetUri = await filePicker.save({newFileNames: ['backup.db']});
    await fs.copyFile(backupPath, targetUri[0]);
}

二、查看数据库内容

必备条件

  1. 三个文件必须保持在同一目录
  2. 文件名必须保持原始名称
  3. 使用支持WAL模式的工具(推荐SQLiteStudio)

查看步骤(SQLiteStudio)

  1. 下载安装 SQLiteStudio
  2. 打开软件 → Database → Add a database
  3. 选择导出的 .db 文件
  4. 关键设置 :勾选 Use WAL mode (Write-Ahead Logging)
  5. 双击左侧数据库连接 → 展开Tables查看数据表
  6. 右键表名 → Edit table 查看数据

sqlitestudio.pl/images/scre...

三、常见问题解决

问题现象 原因 解决方案
看不到最新数据 WAL文件未正确处理 1. 确认三个文件在同一目录 2. 执行SQL命令:PRAGMA journal_mode=DELETE;
"database disk image is malformed" 文件导出不完整 1. 重新导出三个文件 2. 使用代码备份后导出单个backup.db文件
加密数据库无法打开 缺少密钥 1. 代码中配置加密密钥 2. 在SQLiteStudio中选择SQLCipher标签输入密钥
导出文件权限不足 未声明文件权限 在module.json5中添加: "requestPermissions": [{ "name": "ohos.permission.FILE_ACCESS_PERSISTED" }]

四、高级技巧

命令行查看(需安装SQLite3)

bash

sql 复制代码
sqlite3 数据库名.db

-- 合并WAL文件
PRAGMA wal_checkpoint(FULL);

-- 查看所有表
.tables

-- 查询数据
SELECT * FROM 表名;

导出为JSON(代码实现)

typescript

typescript 复制代码
async exportToJSON(tableName: string) {
    const data = await this.rdbStore.query(`SELECT * FROM ${tableName}`);
    const jsonStr = JSON.stringify(data);
    
    const filePicker = new picker.DocumentViewPicker();
    const uri = await filePicker.save({
        newFileNames: [`${tableName}.json`]
    });
    
    await fs.writeText(uri[0], jsonStr);
}

五、注意事项

  1. 必须同时导出三个文件(.db、.db-wal、.db-shm)
  2. 开发阶段优先使用DevEco Studio导出
相关推荐
li理2 小时前
鸿蒙Image Kit深度解析:从图片解码到高级特效处理
harmonyos
li理2 小时前
鸿蒙相机开发中篇:自定义 UI 与拍摄控制
harmonyos
鸿蒙小白龙7 小时前
OpenHarmony 与 HarmonyOS 的 NAPI 开发实战对比:自上而下与自下而上的差异解析
harmonyos·鸿蒙·鸿蒙系统·open harmony
喵手8 小时前
【参赛心得】从“碰一碰”到“服务流转”:HarmonyOS创新赛金奖作品“智游文博”全流程复盘!
华为·harmonyos·鸿蒙应用开发·1024征文
鸿蒙小白龙8 小时前
OpenHarmony平台大语言模型本地推理:llama深度适配与部署技术详解
人工智能·语言模型·harmonyos·鸿蒙·鸿蒙系统·llama·open harmony
安卓开发者8 小时前
鸿蒙NEXT Wear Engine开发实战:手机侧应用如何调用穿戴设备能力
华为·智能手机·harmonyos
Damon小智9 小时前
仓颉 Markdown 解析库在 HarmonyOS 应用中的实践
华为·typescript·harmonyos·markdown·三方库
ZIM学编程10 小时前
把握鸿蒙生态红利:HarmonyOS 应用开发学习路径与实战课程推荐
学习·华为·harmonyos
安卓开发者1 天前
鸿蒙NEXT应用接入快捷栏:一键直达,提升用户体验
java·harmonyos·ux
HMS Core1 天前
消息推送策略:如何在营销与用户体验间找到最佳平衡点
华为·harmonyos·ux