Androidのは、私たちは簡単にデータベースを管理するために私たちを助けるためにクラスSQLiteOpenHelperのヘルプを提供します。しかし、SQLiteOpenHelperは抽象クラスであり、我々はそれを継承し、これらの2つの方法は、論理データベースをアップグレード、作成するために、書き込みにするそののonCreate()、ONUPGRADE()メソッドをオーバーライドするための独自のクラスを作成する必要があります。
getReadableDatabase()、getwriteableDatabase(データベースが既にデータベースを作成するには、直接開いて、または自分自身に存在する場合)()既存のデータベースを作成したり、開くことができます、しかし、データベースを書き込むことができないとき、getReadableDatabase()メソッドのみすることができます読み取り専用モードでデータベースを開き、getwriteableDatabase()メソッドエラーが発生します。
public class MyDatabaseHelper extends SQLiteOpenHelper {
public static final String CREAT_BOOK="creat table book ("
+"id integer primary key autoincrement,"
+"author text,"
+"price real,"
+"pages integer,"
+"name text)";
private Context mContext;
public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
this.mContext = mContext;
}
@Override
public void onCreate(SQLiteDatabase db){
db.execSQL(CREAT_BOOK);
Toast.makeText(mContext,"Create suceeded",Toast.LENGTH_SHORT).show();
}
@Override
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){
}
}
ここでは、私はクラスその継承MyDatabaseHelper SQLiteOpenHelper抽象クラスを作成し、コンストラクタをオーバーライドします。ここでは、私は単純に、コンストラクタ内の様々なパラメータがあると言う:最初のコンテキストで、第二は、データベースの名前である、それは、第三のパラメータはカーソル、一般的なパスはnullデータを照会するとき、私たちが戻ることを可能にする第四パラメータであり、これは、データベースのバージョン番号を示し、ここで、我々はまた、ビルドテーブルステートメントは、文字列定数として定義され、その後、私たちはこの声明の履行の内側に行くためには、ExecSQL()メソッドのonCreate()メソッドを呼び出して、テーブルを構築トーストをポップアップ表示することです。
XMLコードを貼り付けます
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<Button
android:id="@+id/create_database"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Create database"/>
</LinearLayout>
コードMainActivityを貼り付け
public class MainActivity extends AppCompatActivity {
private MyDatabaseHelper dbHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
dbHelper=new MyDatabaseHelper(getApplicationContext(),"BookStore",null,1);
Button createDatabase=(Button)findViewById(R.id.create_database);
createDatabase.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
dbHelper.getReadableDatabase();
}
});
}
}
この操作の後、データベースは成功を確立します。
データベースのアップグレード
上記では、我々は、この方法では、データベースをアップグレードするために使用され、MyDatabaseHelperにONUPGRADE()メソッドを書き換えないでください。
次に、我々はMyDatabaseHelperを追加したデータベース、内部のテーブルを追加する必要があります
public static final String CREATE_CATEGORY="create table Category("
+"id integer primary key autoincrement,"
+"category_name text,"
+"category_code integer)";
@Override
public void onCreate(SQLiteDatabase db){
db.execSQL(CREAT_BOOK);
db.execSQL(CREATE_CATEGORY);
Toast.makeText(mContext,"Create suceeded",Toast.LENGTH_SHORT).show();
}
しかし、上記の例の後、我々の前に実行した場合、我々は再び我々はそれをしたいとの結果がではありません実行することを見つけることがあり、この時ので、何がそれの原因は?その理由は、データベースがすでにこの時間(私たちが作成したデータベースを初めて実行する)に存在することです。我々はButtonボタンをクリックして、MyDatabaseHelperのonCreate()メソッド内ではもはや実行されません。今回は、機能SQLiteOpenHelperのアップグレードを実行する必要があります。次のようにコードを変更
@Override
public void onCreate(SQLiteDatabase db){
db.execSQL(CREAT_BOOK);
db.execSQL(CREATE_CATEGORY);
Toast.makeText(mContext,"Create suceeded",Toast.LENGTH_SHORT).show();
}
@Override
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){
db.execSQL("drop table if exists Book");
db.execSQL("drop table if exists Category");
onCreate(db);
}
それはデータベースの中に発見された場合、私はすでに、その後のonCreate()メソッドを実行し、その後、削除するためにそれを置く、と、ブックのテーブルやカテゴリー、テーブルが存在する、2つのDROP文でONUPGRADE()メソッドを実行しました。