我必须为一个应用程序设置2个数据库。我做了&在模拟器中正常工作。模拟器minSDKVersion是:8真正的手机版本是:2.2.1。 IT支持。当我在真实手机中设置数据库时,我无法设置。总是我无法创建DB。我认为一个是根源,因为当我去File explore - >数据。我无法打开数据文件夹。
我对apk有疑问,因为我的应用程序大小是8 MB。它包含资产文件夹中的数据库。这个大小是4.65 MB。但apk文件大小为1.14MB。
如何从资产文件夹中读取(在真实手机中)?
我真的不知道这是错还是错..这是我的疑问。请解释一下。
我收到了错误:
请帮我。
我的编码部分或其他部分是否有任何错误?
请帮帮我。
提前致谢....
被修改
这是我的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是WindowsMobile®6.5Professional。
请帮帮我。
提前致谢...
答案 0 :(得分:1)
问题是您无法从资产文件夹中读取数据。确保DB_NAME
具有表单
"mydatabase.db"
(包括扩展名)。尝试使用小写,可能区分大小写。
答案 1 :(得分:0)
感谢您发布源代码,我在方法中看到了问题:copyDataBase()
因为DB_NAME
的错误路径,正确的是“databases / MasterUserVentura_HEMA.db”
试试这个:
InputStream myInput = myContext.getAssets().open("databases/MasterUserVentura_HEMA.db");