0

我有一个应用程序在同一个数据库中使用 2 个表。我在帮助程序类中创建并预填充这些表,如下所示。

public void onCreate(SQLiteDatabase db) {

    String sql = "CREATE  TABLE [weekmenu] ([weekmenuID] INTEGER PRIMARY KEY  AUTOINCREMENT  NOT NULL  UNIQUE, [receptenLijst] VARCHAR(50) NOT NULL )";
    db.execSQL(sql);

    sql = "INSERT INTO weekmenu (receptenLijst) values('0')"; db.execSQL(sql);


    sql = "CREATE  TABLE [recepten] ([receptID] INTEGER PRIMARY KEY  AUTOINCREMENT  NOT NULL  UNIQUE, [receptNaam] TEXT NOT NULL  UNIQUE, [receptURL] TEXT )";
    db.execSQL(sql);

    sql = "INSERT INTO recepten (receptNaam, receptURL) values('Macaroni met spek en broccoli', 'http://www.kooknet.be/recepten/hoofdgerecht/macaroni-met-spek-en-broccoli')"; db.execSQL(sql);
    sql = "INSERT INTO recepten (receptNaam, receptURL) values('Broccolipuree met spekblokjes en fishsticks', 'http://www.kooknet.be/recepten/hoofdgerecht/broccolipuree-met-spekblokjes-en-fishsticks')"; db.execSQL(sql);
    sql = "INSERT INTO recepten (receptNaam, receptURL) values('Hoeveomelet', 'http://www.kooknet.be/recepten/hoofdgerecht/hoeveomelet')"; db.execSQL(sql);
    sql = "INSERT INTO recepten (receptNaam, receptURL) values('Gevulde courgettes', 'http://www.kooknet.be/recepten/hoofdgerecht/gevulde-courgettes')"; db.execSQL(sql);   

}

在另一个活动中,我想确保用户在按下按钮时可以更新表格周菜单。每次用户点击按钮时,应覆盖周菜单中的相同记录(通过更新表)

        btnWeekmenuOpslaan.setOnClickListener(new View.OnClickListener() {
        // Database aanroepen
        SQLiteDatabase db = oData.getReadableDatabase();

        @Override
        public void onClick(View v) {


            ContentValues values = new ContentValues();
            String receptenLijst =
                    txtMaandagReceptID.getText().toString() + "-" +
                    txtDinsdagReceptID.getText().toString() + "-" +
                    txtWoensdagReceptID.getText().toString() + "-" +
                    txtDonderdagReceptID.getText().toString() + "-" +
                    txtVrijdagReceptID.getText().toString() + "-" +
                    txtZaterdagReceptID.getText().toString() + "-" +
                    txtZondagReceptID.getText().toString();

            // database updaten
            values.put("receptenLijst", receptenLijst);         
            db.update("weekmenu", values, "weekmenuID=?",new String[] {Long.toString(1)});
            db.close();
            oData.close();              
        }
    });

不幸的是,活动停止并且在调试模式下我收到“weekmenu:不存在这样的表”的消息。

任何人都可以帮助我吗?我一直在阅读 Stackoverflow 上的很多帖子,但没有一个可以帮助我。

谢谢!

4

1 回答 1

0

你的罪魁祸首在这里:

SQLiteDatabase db = oData.getReadableDatabase();

你需要一个可写的数据库。不是一个可读的。

将其更改为:

QLiteDatabase db = oData.getWritableDatabase();
于 2013-11-05T21:55:57.457 回答