请问我为什么会收到错误“SQLiteException:no such table:tabella(code1)???
来自LogCat的我得到:“SQLiteException:没有这样的表:tabella(code1)”当我尝试从活动中访问数据库时。
这是SQLiteOpenHelper代码:
public class DatabaseHelper extends SQLiteOpenHelper {
private static final String CREATE_DB_SQL = "CREATE TABLE tabella (_id INTEGER PRIMARY KEY AUTOINCREMENT, colonna1 TEXT, colonna2 TEXT, colonna3 TEXT);";
public DatabaseHelper(Context context) {
super(context, "basedati", null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_DB_SQL);
ContentValues cv = new ContentValues (3);
cv.put("colonna1", "valore colonna 1");
cv.put("colonna2", "valore colonna 3");
cv.put("colonna3", "valore colonna 3");
db.insert("tabella", "colonna1", cv);
}
@Override
public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) {
db.execSQL("DROP TABLE IF EXISTS tabella");
onCreate(db);
}
}
以下是我尝试打开数据库的活动代码:
public class MainActivity extends Activity {
private DatabaseHelper db=null;
private Cursor constantsCursor=null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
db = new DatabaseHelper(this);
constantsCursor=db.getReadableDatabase().rawQuery("SELECT colonna1 FROM tabella ORDER BY colonna1", null);
}
}
答案 0 :(得分:0)
可能性是您在运行应用程序至少一次后更改了表格。您不能简单地更改Java字符串CREATE_DB_SQL
,还必须更新SQL模式。最简单的方法是增加版本号:
public DatabaseHelper(Context context) {
super(context, "basedati", null, 2); // Change the number to two
}