1

Androidで作成済みのデータベースsqliteを使用することは可能ですか? Mozillaアドオンのsqliteでデータベースを作成しました。Android アプリケーションでどのように使用すればよいですか? 誰でも私を助けることができますか??

4

3 に答える 3

2

まず、データベースを使用するには、一般的に、Android でSQLiteOpenHelperクラスを拡張する必要があります。このクラスは、実装で提供する SQL スクリプトから必要な場合に、データベースの作成 (およびアップグレード) を担当するクラスです。

つまり、データベースを作成するのではなく、assets フォルダーからデータベース ファイルSQLiteOpenHelperコピーするには、 の動作をオーバーライドする必要があります。

このブログ投稿では、この動作をオーバーライドするプロセスについて詳しく説明します。しかし、これが最終的なコードです。

通常どおりにRepositoryクラスを使用します。SQLiteOpenHelper

public class Repository extends SQLiteOpenHelper {
private static final int VERSION = 1;
private static final String DATABASE_NAME = "data.sqlite";
private static File DATABASE_FILE;
// This is an indicator if we need to copy the
// database file.
private boolean mInvalidDatabaseFile = false;
private boolean mIsUpgraded = false;
private Context mContext;
/**
* number of users of the database connection.
* */
private int mOpenConnections = 0;
private static Repository mInstance;

synchronized static public Repository getInstance(Context context) {
    if (mInstance == null) {
        mInstance = new Repository(context.getApplicationContext());
    }
    return mInstance;
}
private Repository(Context context) {
    super(context, DATABASE_NAME, null, VERSION);
    this.mContext = context;
    SQLiteDatabase db = null;
    try {
        db = getReadableDatabase();
        if (db != null) {
            db.close();
        }
        DATABASE_FILE = context.getDatabasePath(DATABASE_NAME);
        if (mInvalidDatabaseFile) {
            copyDatabase();
        }
        if (mIsUpgraded) {
            doUpgrade();
        }
    } catch (SQLiteException e) {
    } finally {
        if (db != null && db.isOpen()) {
            db.close();
        }
    }
}
@Override
public void onCreate(SQLiteDatabase db) {
    mInvalidDatabaseFile = true;
}
@Override
public void onUpgrade(SQLiteDatabase database,
                      int old_version, int new_version) {
    mInvalidDatabaseFile = true;
    mIsUpgraded = true;
}
/**
* called if a database upgrade is needed
*/
private void doUpgrade() {
    // implement the database upgrade here.
}
@Override
public synchronized void onOpen(SQLiteDatabase db) {
    super.onOpen(db);
    // increment the number of users of the database connection.
    mOpenConnections++;
    if (!db.isReadOnly()) {
        // Enable foreign key constraints
        db.execSQL("PRAGMA foreign_keys=ON;");
    }
}
/**
* implementation to avoid closing the database connection while it is in
* use by others.
*/
@Override
public synchronized void close() {
    mOpenConnections--;
    if (mOpenConnections == 0) {
        super.close();
    }
}
private void copyDatabase() {
    AssetManager assetManager = mContext.getResources().getAssets();
    InputStream in = null;
    OutputStream out = null;
    try {
        in = assetManager.open(DATABASE_NAME);
        out = new FileOutputStream(DATABASE_FILE);
        byte[] buffer = new byte[1024];
        int read = 0;
        while ((read = in.read(buffer)) != -1) {
            out.write(buffer, 0, read);
        }
    } catch (IOException e) {
    } finally {
        if (in != null) {
            try {
                in.close();
            } catch (IOException e) {}
        }
        if (out != null) {
            try {
                out.close();
            } catch (IOException e) {}
        }
    }
    setDatabaseVersion();
    mInvalidDatabaseFile = false;
}
private void setDatabaseVersion() {
    SQLiteDatabase db = null;
    try {
        db = SQLiteDatabase.openDatabase(DATABASE_FILE.getAbsolutePath(), null,
                                         SQLiteDatabase.OPEN_READWRITE);
        db.execSQL("PRAGMA user_version = " + VERSION);
    } catch (SQLiteException e ) {
    } finally {
        if (db != null && db.isOpen()) {
            db.close();
        }
    }
}
}
于 2013-05-15T11:33:12.853 に答える
1

sqlite データベースを assets フォルダーに配置するだけで、アプリの初回起動時にデータベースを SDCard にコピーできます。

これを行う方法の詳細な説明を次に示します。

于 2013-05-15T01:36:44.780 に答える
0

Android は SQLite 用の内部データベースを使用します。外部 SQLite データベース (またはその他の外部データベース) を使用する場合は、HHTP プロキシのようなものを使用する必要があります。詳細情報を提供するリンクは次のとおりです。https://stackoverflow.com/a/4124829/1852466

于 2013-05-15T01:30:20.580 に答える