如何从Android中的SQLite删除所有项目

时间:2011-04-16 01:22:17

标签: android sqlite sql-delete

我想创建一个用户单击按钮的应用程序,并清除SQLite数据库。这是我到目前为止所尝试的内容:

db.delete(TABLE_NAME, null, null);

我做错了什么?

9 个答案:

答案 0 :(得分:45)

您的delete()调用是否正确。你有可写的数据库吗?以下是使用delete的方法示例:

/**
 * Remove all users and groups from database.
 */
public void removeAll()
{
    // db.delete(String tableName, String whereClause, String[] whereArgs);
    // If whereClause is null, it will delete all rows.
    SQLiteDatabase db = helper.getWritableDatabase(); // helper is object extends SQLiteOpenHelper
    db.delete(DatabaseHelper.TAB_USERS, null, null);
    db.delete(DatabaseHelper.TAB_USERS_GROUP, null, null);
}

答案 1 :(得分:16)

db.delete(TABLE_NAME,null,null);是删除表中所有行的正确语法。但我认为你可以直接给出表名而不用双引号括起来。试试这样

db.delete("TABLE_NAME", null, null);

可能会有所帮助:)

答案 2 :(得分:3)

使用此代码清除所有数据库内容

Cursor c = db.rawQuery("SELECT name FROM sqlite_master WHERE type='table'", null);
String tableName="";
  if (c.moveToFirst()) {

      while ( !c.isAfterLast() ) {

          tableName = c.getString( c.getColumnIndex("name"));
          if(!tableName.equals('android_metadata')){
            db.execSQL("DROP TABLE '"+tableName+"'");
          }
          c.moveToNext();
      }
  }

c.close();

答案 3 :(得分:3)

实际上,我这样做的另一种方式是DROP表格,然后只为onCreate调用SQLiteDatabase方法。我不知道哪个是最有效率的DeleteDrop因为我没有深入研究每种方法的效率,但它对我来说很有用,因为在我的初始数据库中我有一些默认值值设置,所以当我为数据库调用onCreate方法时,我也有一些PUT方法。这节省了代码复制。 (而不是执行删除然后执行puts我从onCreate函数中获得多用途。)

我称之为reset。因此,您只需执行db.reset(),然后在制作表格后在onCreate中添加默认值。

public void reset () throws SQLException {
    db = DBHelper.getWritableDatabase ();
    db.execSQL ("drop table "+TABLE_NAME);
    db.close ();
    this.DBHelper.onCreate (this.db);
}

答案 4 :(得分:2)

SQLiteDatabase db = this.getWritableDatabase(); //get database
        db.execSQL("DELETE FROM tablename"); //delete all rows in a table
db.close();

答案 5 :(得分:1)

使用此代码:

export default{
 mounted(){
   this.$firebase....
   }
 }

你可以添加它的DatabaseHandler类,这是完整的源代码:

public void deleteAll()
{
    SQLiteDatabase db = this.getWritableDatabase();
    db.execSQL("delete from "+ TABLE_NAME);
    db.close();
}

答案 6 :(得分:0)

对我来说是经典的mysql语句:

SQLiteDatabase sqLiteDatabase = context.openOrCreateDatabase(Database.DATABASE_NAME, Context.MODE_PRIVATE, null, null);
sqLiteDatabase.execSQL("DELETE FROM " + tableName1);
sqLiteDatabase.execSQL("DELETE FROM " + tableName2);
sqLiteDatabase.execSQL("DELETE FROM " + tableName3);
sqLiteDatabase.execSQL("DELETE FROM " + tableName4);

工作得很好。祝你好运:)
ps。:没有开始/结束事务或closeDatabase ...

答案 7 :(得分:0)

在设备上进行开发时可以尝试的一件事:

设置>>应用程序>>(您的应用程序名称)>>存储>>清除缓存和清除数据

通过清除应用程序数据和应用程序缓存,您还可以擦除sql数据库。

答案 8 :(得分:0)

这对我有用:

 public void removeAll()
{

    SQLiteDatabase db = this.getWritableDatabase(); 
    db.delete(TABLE_NAME, null, null);
    db.close();



}