真正的HTC手机中的Android sqlite数据库复制错误

时间:2011-07-27 09:46:55

标签: android database sqlite

我必须为一个应用程序设置2个数据库。我做了&在模拟器中正常工作。模拟器minSDKVersion是:8真正的手机版本是:2.2.1。 IT支持。当我在真实手机中设置数据库时,我无法设置。总是我无法创建DB。我认为一个是根源,因为当我去File explore - >数据。我无法打开数据文件夹。

我对apk有疑问,因为我的应用程序大小是8 MB。它包含资产文件夹中的数据库。这个大小是4.65 MB。但apk文件大小为1.14MB。

如何从资产文件夹中读取(在真实手机中)?

我真的不知道这是错还是错..这是我的疑问。请解释一下。

我收到了错误:

enter image description here 请帮我。

我的编码部分或其他部分是否有任何错误?

请帮帮我。

提前致谢....

被修改

这是我的copyDatabase代码:

公共类DataBaseMasterHelper扩展了SQLiteOpenHelper {

// The Android's default system path of your application database.
private static String DB_PATH = "/data/data/com.android.xont.controller/databases/";
private static String DB_NAME = "MasterUserVentura_HEMA.db";
private SQLiteDatabase ventura;
private  Context myContext;
private DataBaseHelper myDbHelper;

public DataBaseMasterHelper(Context context) {
    super(context, DB_NAME, null, 1);
    this.myContext = context;
}

/**
 * Creates a empty database on the system and rewrites it with your own
 * database.
 **/
public void createDataBase() throws IOException {

    boolean dbExist = checkDataBase();
    File Path = myContext.getDir("Data", 0);
    File DBFile = new File(Path, DB_NAME);
    System.out.println("-------" + DB_NAME);
    if(!DBFile.exists())  //Need to copy...
        copyDataBase(myContext, DBFile);

}

public boolean checkDataBase() {
    SQLiteDatabase checkDB = null;
    try {
        String myPath = DB_PATH + DB_NAME;
        checkDB = SQLiteDatabase.openDatabase(myPath, null,SQLiteDatabase.OPEN_READONLY);
    } catch (SQLiteException e) {
        e.printStackTrace();
    }

    if (checkDB != null) {
        checkDB.close();
    }

    return checkDB != null ? true : false;
}

private void copyDataBase(Context Ctxt, File DBFile) throws IOException {
    InputStream myInput = myContext.getAssets().open(DB_NAME);
    String outFileName = DB_PATH + DB_NAME;
    OutputStream myOutput = new FileOutputStream(outFileName);
    byte[] buffer = new byte[1024];
    int length;
    while ((length = myInput.read(buffer)) > 0) {
        myOutput.write(buffer, 0, length);
    }
    myOutput.flush();
    myOutput.close();
    myInput.close();


}

public void openDataBase() throws SQLException {
    String myPath = DB_PATH + DB_NAME;
    ventura = SQLiteDatabase.openDatabase(myPath, null,
            SQLiteDatabase.OPEN_READONLY);

}

@Override
public synchronized void close() {
    if (ventura != null)
        super.close();
        ventura.close();
}

并且这样打电话:

  MyGrid.setOnItemClickListener(new OnItemClickListener() {
        public void onItemClick(AdapterView parent, View v, int position,long id) {

            if (position == 0) {
                try {
                    myDbMasterHelper.createDataBase();
                    Toast.makeText(DatabaseSetupActivity.this, "Successfully copied database",Toast.LENGTH_SHORT).show();
                } catch (IOException ioe) {
                    Toast.makeText(DatabaseSetupActivity.this, "Unable to create database",Toast.LENGTH_SHORT).show();
                    ioe.printStackTrace();
                }catch (Exception ioe) {
                    Toast.makeText(DatabaseSetupActivity.this, "Unable to create database",Toast.LENGTH_SHORT).show();
                    ioe.printStackTrace();
                }


            }else if (position == 1) {
                try {
                    myDbHelper.createDataBase();
                    Toast.makeText(DatabaseSetupActivity.this, "Successfully copied database",Toast.LENGTH_SHORT).show();
                } catch (IOException ioe) {
                    Toast.makeText(DatabaseSetupActivity.this, "Unable to create database",Toast.LENGTH_SHORT).show();
                    ioe.printStackTrace();

                }catch (Exception ioe) {
                    Toast.makeText(DatabaseSetupActivity.this, "Unable to create database",Toast.LENGTH_SHORT).show();
                    ioe.printStackTrace();
                }



            }
        }
    });

正常运行模拟器。如果文件大小有问题,那么在模拟器中也应该得到错误吗?

我得到这样的错误:

 java.io.FileNotFoundException: /data/data/com.android.xont.controller/databases /MasterUserVentura_HEMA.db (No such file or directory)

我更改了e.printStackTrace()而不是throw expecption。

我认为,这不是文件大小问题。因为我在小尺寸300kb(testng2.db)中做了同样的事情。那个也给出了相同的错误

我的手机 HTC HD2是WindowsMo​​bile®6.5Professional。

请帮帮我。

提前致谢...

2 个答案:

答案 0 :(得分:1)

问题是您无法从资产文件夹中读取数据。确保DB_NAME具有表单 "mydatabase.db"(包括扩展名)。尝试使用小写,可能区分大小写。

答案 1 :(得分:0)

感谢您发布源代码,我在方法中看到了问题:copyDataBase() 因为DB_NAME的错误路径,正确的是“databases / MasterUserVentura_HEMA.db” 试试这个:

InputStream myInput = myContext.getAssets().open("databases/MasterUserVentura_HEMA.db");