【问题标题】:ArrayIndexOutOfBoundException to delete single recordArrayIndexOutOfBoundException 删除单条记录
【发布时间】:2018-06-11 17:59:21
【问题描述】:

我正在使用带有预填充数据的外部数据库。用户还可以在该数据库中执行 CRUD 操作。但是当我删除记录时,它会抛出 Array 超出范围的异常。这是我为删除记录而实现的代码中的 sn-p。

String part[] = ((ItemModel) parent.getItemAtPosition(position)).getName().split("-");
String childQuery = "delete from Stock where item_id = (select id from Item where name = '" + part[0].trim() + "' and size = " + part[1].trim() + ")";
DBHelper.execute(childQuery);
String deleteQuery = "delete from Item where name  = '" + part[0].trim() + "' and size = " + part[1].trim() + " ";
DBHelper.execute(deleteQuery);
customAdapter.notifyDataSetChanged();
dismiss();

try {
    if (!TextUtils.isEmpty(InOutStockActivity.etInOutName.getText().toString())) {
        InOutStockActivity.etInOutName.setText("");
    }

    if (!TextUtils.isEmpty(TotalStockActivity.etTotalName.getText().toString())) {
        TotalStockActivity.etTotalName.setText("");
    }
} catch (NullPointerException e) {
    e.printStackTrace();
}
TastyToast.makeText(mContext, "Record Deleted Successfully.", TastyToast.LENGTH_LONG, TastyToast.DEFAULT);

这里是我的 logcat 中的错误。

java.lang.ArrayIndexOutOfBoundsException: length=1; index=1
at com.v.m.fragment.NameFragment$2$1.onClick(NameFragment.java:102)
at android.support.v7.app.AlertController$ButtonHandler.handleMessage(AlertController.java:162)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6682)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1520)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1410)

提前致谢。

【问题讨论】:

  • 我不是 SQL 专家,但这看起来像是经典的注入:String childQuery = "delete from Stock where item_id = (select id from Item where name = '" + part[0].trim() + "' and size = " + part[1].trim() + ")";。我认为您应该使用PreparedStatement。另见android sqlite prepared statement

标签: android sqlite android-sqlite sqliteopenhelper android-sql


【解决方案1】:

name 不包含“-”,但您的代码假定它。

【讨论】:

    猜你喜欢
    • 2018-06-11
    • 2016-08-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-06-10
    • 1970-01-01
    相关资源
    最近更新 更多