android getWritableDatabase() вылетает

Таким образом, я видел много ответов на эту тему, но ни один не работал, или я действительно не понял, что делать! xD так что если вы ответите, связав тему, которая отвечает, что хорошо!

У меня есть MainActivity, где я показываю свои вещи и все, и класс dbHandler.

В моем классе dbHandler некоторые функции вызывают getWritableDatabase(), и когда они вызывают в моей MainActivity, мое приложение вылетает:/, я увидел, что не должен использовать его в dbHandler, потому что его нельзя вызвать рекурсивно, но я не посмотрим где это называется рекурсивно... xD

Вот MainActivity под названием Accueil, есть больше кода, но я вырезал бесполезный код, и должны быть слова на французском, это нормально, я делаю много усилий 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;
    }
}

LogCat

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)

1 ответ

Решение
String query = "CREATE TABLE " + DATABASE_NAME + "("

Имя базы данных не является именем таблицы.

Другие вопросы по тегам