我是SQLite数据库中的新成员。我目前创建了一个数据库,但我的帮助类中有两个错误,它们是DATABASE_NAME
常量和DATABASE_VERSION
常量的构造函数。 错误说:在超类型构造函数被调用之前不能引用PetDbHelper.DATABASE_NAME
。 我有相同的错误DATABASE_VERSION
常量。 PetDbHelper.java:在SQLite帮助程序类中存在问题
public class PetDbHelper extends SQLiteOpenHelper {
private final String DATABASE_NAME = "shelter.db";
private final int DATABASE_VERSION = 1;
public PetDbHelper(Context context){
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
String SQL_CREATE_PETS_TABLE = "CRAETE TABLE" + PET_ENTRY.TABLE_NAME + "(" + PET_ENTRY._ID + "INTEGER PRIMARY KEY AUTOINCREMENT,"
+ PET_ENTRY.NAME + "TEXT NOT NULL," + PET_ENTRY.BREED + "TEXT," + PET_ENTRY.GENDER + "INTEGER NOT NULL,"
+ PET_ENTRY.WEIGHT + "INTEGER NOT NULL DEFAULT 0);";
sqLiteDatabase.execSQL(SQL_CREATE_PETS_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
使静态DATABASE_NAME,DATABASE_VERSION –
我意识到,我的有关调用回答'super'方法并不适用于这个问题,但你会需要调用'super.onCreate(sqLiteDatabase)'和'super.onUpgrade(sqliteDatabase,i,i1);'来防止不同的崩溃。 –
好的,谢谢@MichaelDodd –