1

私のコードは次のようになりました:

メイン アプリ Java:

    String TAG = "DATABASES";    
    try {

        String destPath = "/data/data/" + getPackageName()
                + "/databases/data.db";

        File f = new File(destPath);
        if(!f.exists()){
            Log.v(TAG,"Dest DB doesn't exist");
            InputStream in = getAssets().open("airports.db");
            OutputStream out = new FileOutputStream(destPath);

            byte[] buffer = new byte[1024];
            int length;
            while ((length = in.read(buffer)) > 0) {
                out.write(buffer, 0, length);
            }
            in.close();
            out.close();
        } else {
            Log.v(TAG,"File exists: " + destPath);  

        }

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch (IOException e) {
        Log.v(TAG,"ioexeption");
        e.printStackTrace();
    }

    DBManager dbManager =  new DBManager(this);
    Log.v(TAG,"Database is there with version: "+dbManager.getReadableDatabase().getVersion());
    //String sql = "select * from airports where IATA='GRO' ";
    String sql = "select count(*) from airports";


    SQLiteDatabase db = dbManager.getReadableDatabase();
    Cursor cursor = db.rawQuery(sql, null);
    Log.v(TAG,"Query Result:"+cursor);


    cursor.close();
    db.close();
    dbManager.close();

私のDBManager.java:

package com.jammo.mywidget4;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

public class DBManager extends SQLiteOpenHelper {

private static final int DATABASE_VERSION = 1;
private static final String TAG = "DATABASES";

public DBManager(Context context) {
    super(context, "data.db", null, DATABASE_VERSION);

}

@Override
public void onCreate(SQLiteDatabase db) {
    Log.v(TAG,"On create Called:"+db.getPath());
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}

現在、実行は「db」の開始時に main.java で正常に実行されますが、rawQuery() を実行しようとする次の行で失敗します。

参考までに、Sqlite DB マネージャーの GUI で「select count(*) from airports」を実行すると、1650 行が返されます。

エラーログは言っています:

03-04 21:54:24.200: E/AndroidRuntime(11513): FATAL EXCEPTION: main
03-04 21:54:24.200: E/AndroidRuntime(11513): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.jammo.mywidget4/com.jammo.mywidget4.SectorInfo}: android.database.sqlite.SQLiteException: no such table: airports: , while compiling: select count(*) from airports

ローカルの /assets/airports.db が検出され、「file is found」として /data/data/mypackage/databases/data.db にコピーされているようです

どうもありがとう

4

1 に答える 1

2

DBManager クラスを使用せずに試してください。

この行をコメントアウト...

DBManager dbManager =  new DBManager(this);

...次に、この行を置き換えてデータベースを明示的に開きます...

SQLiteDatabase db = dbManager.getReadableDatabase();

...と...

SQLiteDatabase db = SQLiteDatabase.openDatabase(destPath, null, SQLiteDatabase.OPEN_READONLY);

次に、アプリのデータをクリアして、データベースがディレクトリから再コピーされるようにしますassets

編集:私の提案はうまくいきましたが、実際には単なる回避策であり、問​​題の根本はこれでした...

String destPath = "/data/data/" + getPackageName() + "/databases/data.db";

Android でハードコーディングされたパスを使用することは避けてください。多くのデバイスで正常に動作する可能性がありますが、すべてのデバイスまたはすべてのバージョンの Android で動作するという保証はありません。

問題は、データベースをそのパスに作成/コピーしていましたが、DBManager クラスがおそらくファイル システムの別のパスにある空のデータベースを作成していたことです。

データベースをコピーする前に、すべてのデバイスと Android バージョンでこれを修正するには、次を使用します...

SQLiteDatabase.openOrCreateDatabase("data.db", null)

...「ダミー」(空の) データベースを作成します。それから私は電話します...

getDatabasePath("data.db")

...への絶対パスを取得しdata.dbます。その後、コピー操作中にそのデータベースを上書きできます。その後、拡張するクラスを使用してSQLiteOpenHelper、正しいデータベースを見つけることができます。

于 2013-03-04T21:27:02.933 に答える