SQLiteOpenHelper类的onCreate方法什么时候被执行
2014-06-03 15:07
253 查看
我们大家都知道Android平台提供给我们一个数据库辅助类来创建或打开数据库,这个辅助类继承自SQLiteOpenHelper类,在该类的 构造器中,调用Context中的方法创建并打开一个指定名称的数据库对象。继承和扩展SQLiteOpenHelper类主要做的工作就是重写以下两个 方法。 onCreate(SQLiteDatabase db) : 当数据库被首次创建时执行该方法,一般将创建表等初始化操作在该方法中执行。 onUpgrade(SQLiteDatabse dv, int oldVersion,int new Version):当打开数据库时传入的版本号与当前的版本号不同时会调用该方法。 除了上述两个必须要实现的方法外,还可以选择性地实现onOpen 方法,该方法会在每次打开数据库时被调用。 SQLiteOpenHelper 类的基本用法是:当需要创建或打开一个数据库并获得数据库对象时,首先根据指定的文件名创建一个辅助对象,然后调用该对象的getWritableDatabase 或 getReadableDatabase方法 获得SQLiteDatabase 对象。 调用getReadableDatabase 方法返回的并不总是只读数据库对象,一般来说该方法和getWriteableDatabase 方法的返回情况相同,只有在数据库仅开放只读权限或磁盘已满时才会返回一个只读的数据库对象。 |
示例代码:
class MyDBHelper extends SQLiteOpenHelper {
public MyDBHelper(Context context, String name,
int version) {
super(context, name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
tableCreate = new StringBuffer();
tableCreate.append("create table ")
.append(DB_TABLENAME)
.append(" (")
.append("_id integer primary key autoincrement,")
.append("name text,")
.append("mobilephone text,")
.append(")");
System.out.println(tableCreate.toString());
db.execSQL(tableCreate.toString());
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
String sql = "drop table if exists " + DB_TABLENAME;
db.execSQL(sql);
myDBHelper.onCreate(db);
}
相关文章推荐
- SQLiteOpenHelper类的onCreate方法什么时候被执行--只有database.db不存在的时候
- SQLiteOpenHelper类的onCreate方法什么时候被执行
- android横竖屏切换,不重新执行onCreate的方法
- onRebind()方法什么时候执行
- Android Activity onCreate()方法重复执行
- SQLiteOpenHelper 用单例模式实现后 onCreate 方法不执行的解决过程
- Android中的Sqlite中的onCreate方法和onUpgrade方法的执行时机
- Android 屏幕旋转后防止重新执行onCreate的方法。
- onSaveInstanceState方法会在什么时候被执行
- Android中的Sqlite中的onCreate方法和onUpgrade方法的执行时机
- onSaveInstanceState方法会在什么时候被执行
- Activity中的onCreate方法不执行问题
- 使用TabHost装载Activity, 当切换activity时,使activity刷新问题(执行oncreate()方法)
- Android中的Sqlite中的onCreate方法和onUpgrade方法的执行时机
- Application中的OnCreate方法执行两次
- android中 onResume()方法什么时候执行 ??(转)
- 解决android程序中oncreate方法中调用百度地图MKSearchListener接口不执行的问题
- 重写 onCreateOptionsMenu(Menu menu) 方法,却不执行。
- JAVA中对象什么时候死亡以及什么时候执行finalize()方法