2017-10-13 25 views
1

我是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) { 

    } 
} 
+0

使静态DATABASE_NAME,DATABASE_VERSION –

+0

我意识到,我的有关调用回答'super'方法并不适用于这个问题,但你会需要调用'super.onCreate(sqLiteDatabase)'和'super.onUpgrade(sqliteDatabase,i,i1);'来防止不同的崩溃。 –

+0

好的,谢谢@MichaelDodd –

回答

3

此变量不能被引用直到父构造函数被初始化。将此变量添加到static修饰符时,不会报告更多错误。

变化

private final String DATABASE_NAME = "shelter.db"; 
private final int DATABASE_VERSION = 1; 

private static final String DATABASE_NAME = "shelter.db"; 
private static final int DATABASE_VERSION = 1; 
+0

它可以工作,但为什么我应该这样做? –

+0

因为你的错误是'在调用超类型构造函数之前不能引用PetDbHelper.DATABASE_NAME''。 – KeLiuyue

+0

它与Java的初始化序列相关联。 – KeLiuyue