在Android SQLITE中删除多行
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在Android SQLITE中删除多行相关的知识,希望对你有一定的参考价值。
在我的应用程序中,我试图同时执行两个删除查询,使用相同的输入删除。我正在使用IN子句。但是我收到了一个错误。我的键是一个String值。
方法....
public void deleteUsingList(String[] ids) {
SQLiteDatabase db = this.getWritableDatabase();
db.delete(TABLE_FAV_AMEN, KEY_AD_ID + " IN (" + "?)", ids);
db.delete(TABLE_FAV_HEAD, KEY_AD_ID + " IN (" + "?)", ids);
db.close();
}
我的错误......
2019-04-14 19:57:48.102 14802-14802/com.estate.dushanmadushanka.estate E/androidRuntime: FATAL EXCEPTION: main
Process: com.estate.dushanmadushanka.estate, PID: 14802
java.lang.IllegalArgumentException: Too many bind arguments. 2 arguments were provided but the statement needs 1 arguments.
at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java)
at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java)
at android.database.sqlite.SQLiteDatabase.delete(SQLiteDatabase.java)
at com.estate.dushanmadushanka.estate.other.SQLiteHandler.deleteUsingList(SQLiteHandler.java:159)
at com.estate.dushanmadushanka.estate.activity.FavouriteActivity$2.onClick(FavouriteActivity.java:84)
at android.view.View.performClick(View.java)
at android.view.View$PerformClick.run(View.java)
at android.os.Handler.handleCallback(Handler.java)
at android.os.Handler.dispatchMessage(Handler.java)
at android.os.Looper.loop(Looper.java)
at android.app.ActivityThread.main(ActivityThread.java)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java)
答案
db.delete(TABLE_NAME, "CAST("+KEY_ID+" AS TEXT) IN (" + new String(new char[ids.length-1]).replace(" ", "?,") + "?)", ids);
另一答案
你不能像这样将参数传递给IN
子句。
我想ids
是你要删除的id的String
数组。
您必须创建一个字符串,其中包含使用ids
分隔的数组,
的所有项:
String strIn = TextUtils.join(",", ids);
你需要这个导入:
import android.text.TextUtils;
然后:
db.delete(TABLE_FAV_AMEN, KEY_AD_ID + " IN (?)", strIn);
如果id是整数,这将起作用,但如果它们是字符串,则必须首先将它们全部用单引号括起来。
以上是关于在Android SQLITE中删除多行的主要内容,如果未能解决你的问题,请参考以下文章
Android 逆向使用 DB Browser 查看并修改 SQLite 数据库 ( 从 Android 应用数据目录中拷贝数据库文件 | 使用 DB Browser 工具查看数据块文件 )(代码片段
Android 逆向使用 DB Browser 查看并修改 SQLite 数据库 ( 从 Android 应用数据目录中拷贝数据库文件 | 使用 DB Browser 工具查看数据块文件 )(代码片段
如何在json android中返回多行并将其传递给sqlite
java.lang.NullPointerException: Attempt to invoke virtual method ‘int android.database.sqlite异常(代码片段