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 + "("
Имя базы данных не является именем таблицы.