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

如何解决如何在Android中从SQLite删除所有项目

|| 我想制作一个用户单击按钮的应用程序,然后清除sqlite数据库。到目前为止,这是我尝试过的操作:
db.delete(TABLE_NAME,null,null);
我究竟做错了什么?     

解决方法

您的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);
}
    ,db.delete(TABLE_NAME,null,null);是删除表中所有行的正确语法。但是我认为您可以直接给定表名,而不必用双引号引起来。这样尝试
db.delete(\"TABLE_NAME\",null);
这可能有帮助:)     ,使用此代码清除所有数据库内容
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();
    ,实际上,我做过的另一种方法是对表进行
DROP
,然后对
SQLiteDatabase
调用
onCreate
方法。我不知道哪个是最有效的
Delete
Drop
,因为我还没有深入研究每种方法的效率,但是它对我很有用,因为在我的初始数据库中我设置了一些默认值,所以当我为数据库调用
onCreate
方法,我那里也有一些
PUT
方法。这样可以节省代码复制。 (而不是先执行删除操作,然后执行看跌期权,我从
onCreate
函数中获得了多功能)。 我称它为“ 12”。因此,您只需要执行
db.reset()
,然后在创建表格后将默认值添加到
onCreate
中。
public void reset () throws SQLException {
    db = DBHelper.getWritableDatabase ();
    db.execSQL (\"drop table \"+TABLE_NAME);
    db.close ();
    this.DBHelper.onCreate (this.db);
}
    ,
SQLiteDatabase db = this.getWritableDatabase(); //get database
        db.execSQL(\"DELETE FROM tablename\"); //delete all rows in a table
db.close();
    ,在设备上进行开发时可以尝试的一件事: 设置>>应用程序>>(您的应用程序名称)>>存储>>清除缓存并清除数据 通过清除应用程序数据和应用程序缓存,您还可以擦除sql数据库。     ,使用此代码:
public void deleteAll()
{
    SQLiteDatabase db = this.getWritableDatabase();
    db.execSQL(\"delete from \"+ TABLE_NAME);
    db.close();
}
您可以添加它DatabaseHandler类,这是完整的源代码:
public class DatabaseHandler extends SQLiteOpenHelper {

// All Static variables
// Database Version
private static final int DATABASE_VERSION = 1;

// Database Name
public static final String DATABASE_NAME = \"OffLineMessagesClient\";

// Contacts table name
public static final String TABLE_NAME = \"messages_client\";

// Contacts Table Columns names
private static final String KEY_ENTITY_ID = \"entity_id\";
private static final String KEY_MESSAGE = \"message\";

public DatabaseHandler(Context context) {
    super(context,DATABASE_NAME,DATABASE_VERSION);
}

// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
    String CREATE_CONTACTS_TABLE = \"CREATE TABLE \" + TABLE_NAME + \"(\"
            + KEY_ENTITY_ID + \" INTEGER,\"
            + KEY_MESSAGE + \" TEXT\"
            +  \")\";

    db.execSQL(CREATE_CONTACTS_TABLE);
}

// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) {
    // Drop older table if existed
    db.execSQL(\"DROP TABLE IF EXISTS \" + TABLE_NAME);

    // Create tables again
    onCreate(db);
}

public void deleteAll()
{
    SQLiteDatabase db = this.getWritableDatabase();
    db.execSQL(\"delete from \"+ TABLE_NAME);
    db.close();
}
}
    ,对我来说经典的mysql语句:
SQLiteDatabase sqLiteDatabase = context.openOrCreateDatabase(Database.DATABASE_NAME,Context.MODE_PRIVATE,null);
sqLiteDatabase.execSQL(\"DELETE FROM \" + tableName1);
sqLiteDatabase.execSQL(\"DELETE FROM \" + tableName2);
sqLiteDatabase.execSQL(\"DELETE FROM \" + tableName3);
sqLiteDatabase.execSQL(\"DELETE FROM \" + tableName4);
工作完美。祝好运 :) 附注:没有start / endtransaction或closeDatabase…     ,这项工作对我来说:
 public void removeAll()
{

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



}
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?