Sqliteexception при обновлении отметки времени? - PullRequest
1 голос
/ 13 февраля 2012

У меня есть этот код:

      String sql="UPDATE  LAST_OPEN  SET  LAST_OPEN="+DATE+"  WHERE  STUDENT_ID ="+STUDENT_ID+"    AND   ITEM_ID="+ITEM_ID+" AND   ITEM_NAME="+ITEM_TYPE+";";

db.execSQL(sql);

Где поле LAST_OPEN является меткой времени. Я пытался выполнить тот же запрос в браузере SQlite, он работал нормально. Но когда этот Sql выполняется в приложении, он показывает это:

       02-13 13:12:39.468: E/AndroidRuntime(2366): FATAL EXCEPTION: main
       02-13 13:12:39.468: E/AndroidRuntime(2366): android.database.sqlite.SQLiteException: near "13": syntax error: UPDATE  LAST_OPEN  SET  LAST_OPEN=2012-02-13 13:12:39  WHERE  STUDENT_ID =5    AND   ITEM_ID=1 AND   ITEM_NAME=Activity;
       02-13 13:12:39.468: E/AndroidRuntime(2366):  at android.database.sqlite.SQLiteDatabase.native_execSQL(Native Method)
       -13 13:12:39.468: E/AndroidRuntime(2366):    at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1727)
        02-13 13:12:39.468: E/AndroidRuntime(2366):     at com.cuelearn.databases.last_open.update(last_open.java:205)
      02-13 13:12:39.468: E/AndroidRuntime(2366):   at com.cuelearn.main.threeshelf$1.onClick(threeshelf.java:197)
      02-13 13:12:39.468: E/AndroidRuntime(2366):   at android.view.View.performClick(View.java:2408)
       02-13 13:12:39.468: E/AndroidRuntime(2366):  at android.view.View$PerformClick.run(View.java:8816)
     02-13 13:12:39.468: E/AndroidRuntime(2366):    at android.os.Handler.handleCallback(Handler.java:587)
      02-13 13:12:39.468: E/AndroidRuntime(2366):   at android.os.Handler.dispatchMessage(Handler.java:92)
       02-13 13:12:39.468: E/AndroidRuntime(2366):  at android.os.Looper.loop(Looper.java:123)
   02-13 13:12:39.468: E/AndroidRuntime(2366):  at android.app.ActivityThread.main(ActivityThread.java:4627)
    02-13 13:12:39.468: E/AndroidRuntime(2366):     at java.lang.reflect.Method.invokeNative(Native Method)
     02-13 13:12:39.468: E/AndroidRuntime(2366):    at java.lang.reflect.Method.invoke(Method.java:521)
       02-13 13:12:39.468: E/AndroidRuntime(2366):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
        02-13 13:12:39.468: E/AndroidRuntime(2366):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)

Может кто-нибудь сказать, где я ошибаюсь?

Ответы [ 2 ]

1 голос
/ 13 февраля 2012

Попробуйте изменить

LAST_OPEN=2012-02-13 13:12:39

на

LAST_OPEN = "2012-02-13 13:12:39"

Пробел между числами может быть проблемой.Надеюсь, это поможет.

1 голос
/ 13 февраля 2012

Попробуйте с помощью этого оператора SQL:

String sql="UPDATE LAST_OPEN SET LAST_OPEN='"+DATE+"' WHERE STUDENT_ID ="+STUDENT_ID+" AND ITEM_ID="+ITEM_ID+" AND ITEM_NAME="+ITEM_TYPE+";";

Как я знаю, когда вы используете строковые данные в выражении sql, вам нужно добавить '' в начале переменной и в конце.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...