-3

所以我看到了很多关于这个话题的答案,但都没有奏效,或者我真的不明白该怎么做!xD,所以如果您通过链接回答很好的主题来回答!

我有一个 MainActivity 来显示我的东西和所有东西,还有一个类 dbHandler。

在我的 dbHandler 类中,一些函数正在调用 getWritableDatabase(),当它们在我的 MainActivity 中调用时,我的应用程序崩溃:/,我看到我不应该在 dbHandler 中使用它,因为它不能被递归调用,但我不看看它在哪里被递归调用...... xD

这是名为 Accueil 的 MainActivity 有更多代码,但我删掉了无用的代码,应该有法语单词,这很正常,我做了很多法语 xD

public class Accueil extends AppCompatActivity {
    TextView textDB;
    dbHandler db_handler;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_accueil);

        textDB = (TextView) findViewById(R.id.textDB);
        db_handler = new dbHandler(this, null, null, 1);
        Alerte alerte = new Alerte("feu");
        db_handler.addAlerte(alerte);
        //printDatabase();

    }

    public void printDatabase(){
        String dbString = db_handler.databaseToString();
        textDB.setText(dbString);
    }
}

和 dbHandler

package com.example.yorokobii.popalerte;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class dbHandler extends SQLiteOpenHelper{

    private static final int DATABASE_VERSION = 1;
    private static final String DATABASE_NAME = "Alertes.db";
    public static final String TABLE_ALERTES = "Alertes";
    public static final String COLUMN_ID = "_id ";
    public static final String COLUMN_ALERTENAME = "alertename ";

    public dbHandler(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 " + DATABASE_NAME + "("
                + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, "
                + COLUMN_ALERTENAME + " TEXT "
                + ");";
        db.execSQL(query);/*

        ContentValues values = new ContentValues();
        values.put(COLUMN_ALERTENAME, "test");
        db.insert(TABLE_ALERTES, null, values);*/
    }

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

    //fonction qui ajoute une alerte a la base de donnée
    public void addAlerte(Alerte alerte){
        ContentValues values = new ContentValues();
        values.put(COLUMN_ALERTENAME, alerte.get_alertename());
        SQLiteDatabase db = getWritableDatabase();
        db.insert(TABLE_ALERTES, null, values); //effectue la requète insert sur TABLE_ALERTES avec les valeur rentrées dans value
        db.close();
    }

    //fonction qui supprime une alerte en fonction de son nom (plus tard son état surement)
    public void deleteAlerte(String alertename){
        SQLiteDatabase db = getWritableDatabase();
        db.execSQL("DELETE FROM " + TABLE_ALERTES + "WHERE " + COLUMN_ALERTENAME + "=\"" + alertename + "\";");
        db.close();
    }

    //fonction qui supprime toutes les alertes
    public void deleteAlerte(){
        SQLiteDatabase db = getWritableDatabase();
        db.execSQL("DELETE FROM " + TABLE_ALERTES + "WHERE 1");
        db.close();
    }

    //fonction qui affiche les alertes dans une chaine de caractère
    public String databaseToString(){
        String dbString = "";
        SQLiteDatabase db = getWritableDatabase();
        String query = "SELECT * FROM " + TABLE_ALERTES;

        //créé un cuseur pour la requète
        Cursor c = db.rawQuery(query, null);

        c.moveToFirst();//place le curseur a la premiere colonne du resultat de la requete

        while(!c.isAfterLast()){ //tant qu'il y a des resultats a traiter
            if(c.getString(c.getColumnIndex(COLUMN_ALERTENAME)) != null){ //si le nom de l'alerte n'est pas null on l'affiche
                dbString = c.getString(c.getColumnIndex(COLUMN_ALERTENAME));
                dbString += "\n";
            }
        }
        db.close();
        return dbString;
    }
}

日志猫

Caused by: android.database.sqlite.SQLiteException: unknown database Alertes (code 1): , while compiling: CREATE TABLE Alertes.db(_id INTEGER PRIMARY KEY AUTOINCREMENT, alertename TEXT );
at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:887)
at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:498)
at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
at android.database.sqlite.SQLiteProgram.(SQLiteProgram.java:58)
at android.database.sqlite.SQLiteStatement.(SQLiteStatement.java:31)
at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1674)
at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1605)
at com.example.yorokobii.popalerte.dbHandler.onCreate(dbHandler.java:27)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:251)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
at com.example.yorokobii.popalerte.Accueil.addAlerte(Accueil.java:173)
at com.example.yorokobii.popalerte.Accueil.onCreate(Accueil.java:115)
at android.app.Activity.performCreate(Activity.java:6237)
4

1 回答 1

1
String query = "CREATE TABLE " + DATABASE_NAME + "("

数据库名不是表名。

于 2016-02-14T09:45:54.643 回答