android之database disk image is malformed (code 11)

本文介绍了一种在下载数据库过程中避免文件损坏的方法。通过调整读取缓冲区大小,解决了因下载过程导致的数据文件格式错误问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

做来电显示归属地和查询归属地功能的时候,需要从服务器下载数据库,

但是下载之后,查询总是报错database disk image is malformed (code 11)

开始以为是查询语句不对,后来意识到,跟之前解析包时出现错误是一样的问题,

下载过程中格式损坏了。

于是解决方法跟http://blog.youkuaiyun.com/jason0539/article/details/21742019采取了一样的策略,

把每次读取的数组缩小,代码如下:

public class DownloadTask {  
      
    /** 
     * @param path下载地址 
     * @param filePath存储路径 
     * @param progressDialog进度条 
     * @return 
     * @throws Exception 
     */  
    public static File getFile(String path,String filePath,ProgressDialog progressDialog) throws Exception{  
          
        URL url = new URL(path);  
        HttpURLConnection connection = (HttpURLConnection) url.openConnection();  
        connection.setConnectTimeout(2000);  
        connection.setRequestMethod("GET");  
        if(connection.getResponseCode() == 200){  
            int total = connection.getContentLength();  
            progressDialog.setMax(total);  
              
            InputStream is = connection.getInputStream();//获得socket输入流  
            File file = new File(filePath);  
            FileOutputStream fos = new FileOutputStream(file);//file输出流  
            byte[] buffer = new byte[1024];  
            int len;  
            int progress = 0;  
            while((len = is.read(buffer)) != -1){  
                fos.write(buffer);  
                progress += len;  
                progressDialog.setProgress(progress);  
            }  
            fos.flush();  
            is.close();  
            fos.close();  
            connection.disconnect();  
            return file;  
        }  
        return null;  
    }  


把里面这行里的1024改小就可以避免损坏了,

 byte[] buffer = new byte[1024];  

由于总是错,我甚至改成了

byte[] buffer = new byte[8];


这样是没错了,但是有个弊端,下载变的很慢,下载的数据库是16M的,奇慢无比,

临时性这样解决了。

 

作者:jason0539

微博:http://weibo.com/2553717707

博客:http://blog.youkuaiyun.com/jason0539(转载请说明出处)

 

### 处理 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、付费专栏及课程。

余额充值