0

我有一个数据库文件没有被读取的问题我已经在名为 mydb 的资产中添加了数据库文件,但是当我运行我的代码时它说它没有被定位。它正在调用这个 toast Toast.makeText(this, "No contact found", Toast.LENGTH_LONG).show(); 之所以调用它,是因为没有返回任何记录。我也知道它正在查找文件,因为没有 FileNotFoundException 异常。这是一个示例形式的 Android 应用程序开发书。

public class DatabaseActivity extends Activity {
    /** Called when the activity is first created. */
    TextView quest, response1, response2;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        TextView quest = (TextView) findViewById(R.id.quest);


        try {           
            String destPath = "/data/data/" + getPackageName() + "/databases/MyDB";
            File f = new File(destPath);            
            if (!f.exists()) {          
                CopyDB( getBaseContext().getAssets().open("mydb"), 
                    new FileOutputStream(destPath));
            }
        } catch (FileNotFoundException e) {         
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

        DBAdapter db = new DBAdapter(this); 


        //---get a contact---
        db.open();
        Cursor c = db.getContact(2);
        if (c.moveToFirst())        
            DisplayContact(c);
        else
            Toast.makeText(this, "No contact found", Toast.LENGTH_LONG).show();
        db.close();



    }

    public void CopyDB(InputStream inputStream, OutputStream outputStream) 
    throws IOException {
        //---copy 1K bytes at a time---
        byte[] buffer = new byte[1024];
        int length;
        while ((length = inputStream.read(buffer)) > 0) {
            outputStream.write(buffer, 0, length);
        }
        inputStream.close();
        outputStream.close();
    }

    public void DisplayContact(Cursor c)
    {
    quest.setText(String.valueOf(c.getString(1)));      
        //quest.setText(String.valueOf("this is a text string"));    
    } 
}

有没有更好的上传数据的方法。

4

1 回答 1

1

这里想到了几件事......

  1. 由于!f.exists()检查,一旦数据库存在(并且可能为空),它将永远不会再次复制它。所以也许现在,一直复制它,直到你解决扭结然后添加!f.exists()

  2. 我的结果好坏参半e.printStackTrace(),也许改成Log.e(TAG, "message", e),看看你是否开始看到 LogCat 中出现错误

至于更好的方法......我已经用几种不同的方式做到了...... 1.是创建一个文件(json,cvs等)然后处理并加载它,如果数据库是空的2.类似于第一个,除了我创建一个 java 序列化对象数组并将其加载到数据库,如果数据库是空的。

另外我不知道是什么DBAdapter样子的,因为它包装了数据库,所以问题可能就在那里。

于 2012-06-05T12:25:30.633 回答