4

抱歉再次打扰,我是 Sqlite 新手,需要一些帮助。

我正在尝试更新表的单行中的单个文件。

我尝试这样做:

db.getWritableDatabase().execSQL("UPDATE data SET korean = "
+kopulito+ " WHERE _id = " + constantsCursor.getString(0), null);

但是我得到了上面提到的错误。这是我的 LogCat。

05-05 09:58:07.776: E/AndroidRuntime(30495): FATAL EXCEPTION: main
05-05 09:58:07.776: E/AndroidRuntime(30495): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.koday/com.example.koday.MainActivity}: java.lang.IllegalArgumentException: Empty bindArgs
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.os.Handler.dispatchMessage(Handler.java:99)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.os.Looper.loop(Looper.java:130)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread.main(ActivityThread.java:3683)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at java.lang.reflect.Method.invokeNative(Native Method)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at java.lang.reflect.Method.invoke(Method.java:507)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at dalvik.system.NativeStart.main(Native Method)
05-05 09:58:07.776: E/AndroidRuntime(30495): Caused by: java.lang.IllegalArgumentException: Empty bindArgs
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1793)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at com.example.koday.MainActivity.updateall(MainActivity.java:301)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at com.example.koday.MainActivity.onCreate(MainActivity.java:72)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-05 09:58:07.776: E/AndroidRuntime(30495):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
05-05 09:58:07.776: E/AndroidRuntime(30495):    ... 11 more

非常感谢。

4

6 回答 6

23

这对我有用:只需从 execSql 命令中删除 null 参数

于 2014-09-16T07:58:44.133 回答
14

实际上您可以execSql用于更新数据。只需在方法中删除“null”参数execSql,因此更改:

db.getWritableDatabase().execSQL("UPDATE data SET korean = " +kopulito+ " WHERE _id = " + constantsCursor.getString(0), null);

db.getWritableDatabase().execSQL("UPDATE data SET korean = " +kopulito+ " WHERE _id = " + constantsCursor.getString(0));

这很完美。

于 2014-06-01T12:54:57.253 回答
1

您可以execSql用于更新数据。

只需null从 execSql 命令中删除参数即可。

于 2013-05-05T10:23:17.500 回答
1

就我而言,我改变了这一行

db.execSQL(query, null);

通过这条线

db.execSQL(query);

它工作。

于 2019-01-06T17:31:12.723 回答
0

方法 execSQL 被重载。使用 execSQL(String SQL) 您可以做任何事情,但不能返回任何数据,因此它可用于插入,例如,我完全有可能在我的应用程序中使用它。

于 2014-07-23T20:23:23.107 回答
0

我只是改变这个:

db.execSQL("UPDATE cars SET fav = " + fav + " WHERE car_id = " + car_id , null);

这样:

db.execSQL("UPDATE cars SET fav = " + fav + " WHERE car_id = " + car_id);
于 2018-09-13T18:14:55.737 回答