可道云kodexplorer报错database disk image is malformed

owncloud, nextcloud应该同理,这类网盘如果你同样是使用的php内置的sqlite作为数据库管理软件,解决方法大同小异。

报错信息

出错了! (warning!)

think_trace();
database disk image is malformed[SQL statement]:SELECT COUNT(*) AS tp_count FROM `group` WHERE ( parentID = '1' )

报错原因我猜测是因为我将可道云安装在了外置硬盘,而不知什么情况我移动硬盘的设备标识符/dev/sdc3改变了,变成了/dev/sdb3,而我用的磁盘管理软件diskman自动挂载路径随之改变成/mnt/sdb3,个人猜测就是应该是因为这个原因导致的。

解决方法

因为用的是php内置的sqlite3,所以数据库文件名后缀是.php而不是.sql或者什么.db

在kodexplorer程序目录下的data/system目录下有一个php文件,可以通过ls -lh查看占用空间最大的那个基本就没错了,我生产环境上的文件路径是/mnt/sdb3/kodexplorer/data/system/t8ZuK56w4Tny.php,文件大小大概是5、6兆。
如果我没记错的话,owncloud的文件结构好像也差不多,在程序的根路径下同样有个data目录。

cd /mnt/sdb3/kodexplorer/data/system/
# 备份
cp t8ZuK56w4Tny.php t8ZuK56w4Tny.php.bak
sqlite3 t8ZuK56w4Tny.php .dump > tmp.php
vim tmp.php

不会用vim就用nano编辑文本,跳转最后一行,将最后一行ROLLBACK; -- due to errors修改成COMMIT;保存退出。BTW, vim按两次Shift+z就可以保存退出,比:wq方便多了。

sqlite3 t8ZuK56w4Tny.php < tmp.php

DONE!

参考:sqlite关于The database disk image is malformed问题的解决

### 处理 SQLite 数据库磁盘映像损坏的方法 当遇到 `sqlite3.DatabaseError: database disk image is malformed` 错误时,表明数据库文件已损坏。此问题可能由多种原因引起,如硬件故障、意外断电或程序异常终止等。 #### 尝试备份现有数据 为了尽可能减少损失,在尝试任何修复措施之前,建议先创建当前数据库的一个副本。这可以防止进一步的操作导致更多不可逆的数据丢失: ```bash cp /path/to/corrupted.db /path/to/backup_corrupted.db ``` #### 使用 `.dump` 命令导出 SQL 脚本并重建数据库 如果能够访问到部分未受损的数据,则可以通过`.dump`命令将整个数据库的内容转储成纯文本形式的SQL语句集,并将其导入新的空白数据库中[^3]。 ```sql -- 导出原始数据库至临时文件 .output temp.sql .dump -- 创建新数据库并将导出内容重新加载进去 .exit sqlite3 new_database.db .read temp.sql ``` #### 执行 PRAGMA integrity_check 和 reindex 操作 对于版本控制系统中的工作拷贝数据库(例如 Subversion 的 wc.db),可利用PRAGMA指令来进行更深入的诊断与修复。具体来说就是运行`integrity_check`来查找潜在的问题区域;接着针对特定索引执行`reindex`动作以优化其结构完整性[^4]。 ```sql -- 检查数据库完整性 pragma integrity_check; -- 重建受影响表格的索引 reindex nodes; reindex pristine; ``` 需要注意的是上述方法并不能保证一定能完全恢复所有的数据项,特别是那些已经严重损毁的部分。因此预防总是优于治疗——定期做好重要资料的安全备份才是最有效的策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值