I have a problem in sqlite database.First i created database externally and then put it in the assets folder.The following code copy the database.
public class DbH extends SQLiteOpenHelper{
private Context mycontext;
private String DB_PATH = "/data/data/com.android.quotes/databases/";
private static String ROW_ID="_id";
private static String DB_NAME = "mdb1.db";
public SQLiteDatabase myDataBase;
/*private String DB_PATH = "/data/data/"
+ mycontext.getApplicationContext().getPackageName()
+ "/databases/";
*/
public DbH(Context context) throws IOException {
super(context,DB_NAME,null,1);
this.mycontext=context;
boolean dbexist = checkdatabase();
if(dbexist){
//System.out.println("Database exists");
opendatabase();
} else {
System.out.println("Database doesn't exist");
createdatabase();
}
}
public void createdatabase() throws IOException{
boolean dbexist = checkdatabase();
if(dbexist){
System.out.println(" Database exists.");
} else {
this.getReadableDatabase();
try{
copydatabase();
} catch(IOException e){
throw new Error("Error copying database");
}
}
}
private boolean checkdatabase() {
//SQLiteDatabase checkdb = null;
boolean checkdb = false;
try{
String myPath = DB_PATH + DB_NAME;
File dbfile = new File(myPath);
SQLiteDatabase.openDatabase
(myPath,null,SQLiteDatabase.OPEN_READWRITE);
checkdb = dbfile.exists();
} catch(SQLiteException e){
System.out.println("Database doesn't exist");
}
return checkdb;
}
private void copydatabase() throws IOException {
//Open your local db as the input stream
InputStream myinput = mycontext.getAssets().open(DB_NAME);
// Path to the just created empty db
String outfilename = DB_PATH + DB_NAME;
//Open the empty db as the output stream
OutputStream myoutput = new FileOutputStream(outfilename);
// transfer byte to inputfile to outputfile
byte[] buffer = new byte[1024];
int length;
while ((length = myinput.read(buffer))>0){
myoutput.write(buffer,0,length);
}
//Close the streams
myoutput.flush();
myoutput.close();
myinput.close();
}
public void opendatabase() throws SQLException{
//Open the database
String mypath = DB_PATH + DB_NAME;
myDataBase = SQLiteDatabase.openDatabase(
mypath, null, SQLiteDatabase.OPEN_READWRITE
);
}
public synchronized void close(){
if(myDataBase != null){
myDataBase.close();
}
super.close();
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// Empty
}
@Override
public void onCreate(SQLiteDatabase arg0) {
// TODO Auto-generated method stub
}
}
In main activity i first call createdatabase and then opendatabase.
Now i craeted only two table in sqlite database one is android_metadata and second is mTable.when i run the program the following errors occur.
- Although database is created and i can see it using file explorer in eclipse but only android_metadata table is there and mTable is not there.
- So it says no such table exists while selecting * from mTable.
Any suggestion where i m going wrong. I m pulling my hair from one week me. Please help.
Thanks in advance.
First Of all check database database exists in internal storage if not than copy
if database not exists then copy from asset to internal storage