开发者

Sqlite database problem android

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 vo开发者_运维知识库id 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.

  1. 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.
  2. 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

private void checkDatabase() {

        StringBuffer dbPath = new StringBuffer();
        File databaseFile;
        // Location of the database file, where it will be stored to access
        // throughout the program.
        dbPath.append("/data/data/");
        dbPath.append(getBaseContext().getPackageName());
        dbPath.append("/databases/");

        // Location of the database file stored in assets folder.
        String storedDatabase = Constants.DATABASE_FILE_NAME;

        // copy the database
        try {

            databaseFile = new File(dbPath.toString(), Constants.DATABASE_FILE_NAME);

            if (databaseFile.exists()) {
                Log.i("database", "database already Exists");

            } else {
                SQLiteDatabase database = openOrCreateDatabase(Constants.DATABASE_FILE_NAME,
                        SQLiteDatabase.OPEN_READONLY, null);
                database.close();
                copyDatasbase(getBaseContext().getAssets(), storedDatabase,
                        dbPath + Constants.DATABASE_FILE_NAME);
            }
        } catch (IOException ioException) {

            ioException.printStackTrace();
        } catch (Exception exception) {

            exception.printStackTrace();
        }

    }

if database not exists then copy from asset to internal storage

private void copyDatasbase(AssetManager manager, String sourceFileName,
            String destinationFileName) throws IOException {

        // Read file from AccessManager
        InputStream inputStream = manager.open(sourceFileName);
        OutputStream outputStream = new FileOutputStream(destinationFileName);
        Log.d("-->", "src: " + sourceFileName);
        Log.d("-->", "Des: " + destinationFileName);
        byte[] buffer = new byte[3072];
        int length;
        while ((length = inputStream.read(buffer)) > 0) {
            // Write the database file to the folder "databases"
            outputStream.write(buffer, 0, length);

        }

        outputStream.flush();
        outputStream.close();
        inputStream.close();

        outputStream = null;
        inputStream = null;
    }
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜