java - 在 SQLite 数据库中添加新列

标签 java android database sqlite

我对 Android 开发还很陌生,我正在尝试为我的应用程序实现一个数据库。 我开始时数据库中只有一列 (COLUMN_DATE),然后添加了另一列 (COLUMN_REPEAT)。这工作得很好并按预期打印了结果。但是,当我尝试添加另一列(COLUMN_ACCOUNT)时,MainActivity 中的 printDatabase() 没有打印任何内容。 我知道您可以使用 Android Device Monitor 查看数据库中的内容,但当我单击它时,我不断收到错误,因此我无法使用它(这是一个我无法解决的单独问题)。因此,我不确定这是否只是打印数据库的问题,或者数据库中是否确实有任何数据。 任何帮助将不胜感激

----MainActivity.java----

dbHandler = new DatabaseHandler(this, null, null, 1);
printDatabase();

//Print the database
public void printDatabase() {
    String dbString = dbHandler.databaseToString();
    recordsTextView.setText(dbString);
}

//Add an item to the database
public void addButtonClicked(View view){
    Income date = new Income(dateView.getText().toString());
    Income repeat = new Income(repeatSpinner.getSelectedItem().toString());
    Income account = new Income(accountSpinner.getSelectedItem().toString());
    dbHandler.addData(date, repeat, account);
   printDatabase();
}

//Delete items with input date from database
public void deleteButtonClicked(View view){
    String inputText = dateView.getText().toString();
    dbHandler.deleteData(inputText);
    printDatabase();
}

----DatabaseHandler.java----

public class DatabaseHandler extends SQLiteOpenHelper{
private static final int DATABASE_VERSION = 1;
private static final String DATABASE_NAME = "IncomeExpenseDB.db";
public static final String TABLE_NAME = "income_expense";
public static final String COLUMN_ID = "_id";
public static final String COLUMN_DATE = "date";
public static final String COLUMN_REPEAT = "repeat";
public static final String COLUMN_ACCOUNT = "account";

public DatabaseHandler(Context context, String name, 
SQLiteDatabase.CursorFactory factory, int version) {
    super(context, DATABASE_NAME, factory, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {
    String query = "CREATE TABLE " + TABLE_NAME + "(" +
            COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
            COLUMN_DATE + " TEXT, " + COLUMN_REPEAT + " TEXT, " + 
            COLUMN_ACCOUNT + " TEXT " +
            ");";
    db.execSQL(query);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
    onCreate(db);
}

//Add a new row to the database
public void addData(Income date, Income repeat, Income 
account){
    ContentValues values = new ContentValues();
    values.put(COLUMN_DATE, date.get_item());
    values.put(COLUMN_REPEAT, repeat.get_item());
    values.put(COLUMN_ACCOUNT, account.get_item());
    SQLiteDatabase db = getWritableDatabase();
    db.insert(TABLE_NAME, null, values);
    db.close();
}


//Delete data from the database
public void deleteData(String date){
    SQLiteDatabase db = getWritableDatabase();
    db.execSQL("DELETE FROM " + TABLE_NAME + " WHERE " + COLUMN_DATE + "=\"" 
    + date + "\";");
}

// Create a string to print out in MainActivity
public String databaseToString() {
    String dbString = "";
    SQLiteDatabase db = getWritableDatabase();
    String query = "SELECT * FROM " + TABLE_NAME + " WHERE 1";
    //Cursor points to a location in results
    Cursor c = db.rawQuery(query, null);
    //Move to first row in results
    c.moveToFirst();
    while (!c.isAfterLast()) {
        if (c.getString(c.getColumnIndex("date")) != null && 
        c.getString(c.getColumnIndex("repeat")) != null && 
        c.getString(c.getColumnIndex("account")) != null) {
            dbString += c.getString(c.getColumnIndex("date"));
            dbString += " ";
            dbString += c.getString(c.getColumnIndex("repeat"));
            dbString += " ";
            dbString += c.getString(c.getColumnIndex("account"));
            dbString += "\n";
        }
        c.moveToNext();
    }
    db.close();
    return dbString;
}

}

----收入.java----

public class Income {
    private int _id;
    private String _item;

    public Income(){
    }
    public Income(String item) {
        this._item = item;
    }
    public int get_id() {
        return _id;
    }
    public void set_id(int _id) {
        this._id = _id;
    }
    public String get_item() {
        return _item;
    }
    public void set_item(String _item) {
        this._item = _item;
    }
}

最佳答案

卸载并重新安装是非常幼稚的方法,仅在开发阶段有效。当您的应用继续上架 Play 商店时,用户不会卸载并重新安装该应用。

更新已发布应用的数据库的正确方法是增加数据库版本并使用 onUpgrade 方法更新数据库。

看看这个方法

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
    onCreate(db);
}

在当前情况下,如果您只是增加数据库版本,它将删除现有表并创建一个包含新列和规范的新表。缺点是您将丢失所有现有数据。

如果你想保存现有数据并向数据库添加新列,你必须这样做 -

@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int oldVersion, int newVersion) {
  switch(oldVersion) {
    case 1:
      //add new column
      sqLiteDatabase.execSQL("ALTER TABLE "+ TABLE_NAME + " ADD COLUMN "+ NEW_COLUMN + " INTEGER/TEXT ");
  }
}

关于java - 在 SQLite 数据库中添加新列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48293441/

相关文章:

android - 在 android java 类中使用 Kotlin 扩展

java - Apache Jackrabbit 和 Spring 中的事务

python - 如何在Python的sqlite3中选择数据列表是所有列的子集

java - 避免 Java 8 Files.walk(..) 终止原因 ( java.nio.file.AccessDeniedException )

java - 使用 java.text.SimpleDateFormat 解析日期字符串

java - 如何读取输入文本? java

java - Dagger2 组件注入(inject)多个 Activity

java - Lwjgl如何简化高度图以获得更高的fps?

android - Google Drive SDK 2.0 抛出错误 400 Bad Request

asp.net - 如何在 EF Core 中向身份用户添加外键?