2011-09-27 6 views
0

이 내 오류입니다 :android.database.sqlite.SQLiteException는 : 근처 "("

09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteCompiledSql.compile(SQLiteCompiledSql.java:92) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:65) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:83) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:41) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteDatabase.compileStatement(SQLiteDatabase.java:1149) 
09-27 08:16:34.547: WARN/System.err(8366):  at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1802) 
09-27 08:16:34.557: WARN/System.err(8366):  at de.enough.appmate.dbase.CMSResource.updateItem(CMSResource.java:1168) 
09-27 08:16:34.557: WARN/System.err(8366):  at de.enough.appmate.dbase.CMSResourceUpdater.updateItems(CMSResourceUpdater.java:179) 
09-27 08:16:34.557: WARN/System.err(8366):  at de.enough.appmate.dbase.CMSResourceUpdater.loadUpdates(CMSResourceUpdater.java:102) 
09-27 08:16:34.557: WARN/System.err(8366):  at de.enough.appmate.dbase.CMSResourceUpdaterRunnable.run(CMSResourceUpdaterRunnable.java:32) 
09-27 08:16:34.557: WARN/System.err(8366):  at java.lang.Thread.run(Thread.java:1019) 

이 데이터베이스가 갱신되어야에 updateItem 방법의 내 코드입니다 :

this.db.execSQL("UPDATE " + CMSConstants.ITEMS + " SET (" + 
        CMSConstants.ID + ", " + 
        CMSConstants.TITLE + ", " + 
        CMSConstants.IS_PAGE + ", " + 
        CMSConstants.IS_HIDDEN + ", " + 
        CMSConstants.ITEM_TYPE + ", " + 
        CMSConstants.ORDER_INDEX + ", " + 
        CMSConstants.SECTION_ID + ", " + 
        CMSConstants.TABLE_SECTION_NAME + ", " + 
        CMSConstants.TABLE_SECTION_ID + ", " + 
        CMSConstants.IMAGE1_FILE + ", " + 
        CMSConstants.IMAGE1_CAPTION + ", " + 
        CMSConstants.IMAGE1_DISPLAY_IN_GALLERY + ", " + 
        CMSConstants.CATEGORY1 + ", " + 
        CMSConstants.CATEGORY2 + ", " + 
        CMSConstants.GEO_LONGITUDE + ", " + 
        CMSConstants.GEO_LATITUDE + ", " + 
        CMSConstants.DESCRIPTION + ", " + 
        CMSConstants.KEYWORDS + ", " + 
        CMSConstants.BLOCKWORDS + ", " + 
        CMSConstants.CLEAN_NAME + ", " + 
        CMSConstants.ADDITIONAL_FIELD1_NAME + ", " + 
        CMSConstants.ADDITIONAL_FIELD1_VALUE + ", " + 
        CMSConstants.ADDITIONAL_FIELD2_NAME + ", " + 
        CMSConstants.ADDITIONAL_FIELD2_VALUE + ", " + 
        CMSConstants.ADDITIONAL_FIELD3_NAME + ", " + 
        CMSConstants.ADDITIONAL_FIELD3_VALUE + ", " + 
        CMSConstants.ADDITIONAL_FIELD4_NAME + ", " + 
        CMSConstants.ADDITIONAL_FIELD4_VALUE + ", " + 
        CMSConstants.ADDRESS_LINE1 + ", " + 
        CMSConstants.ADDRESS_LINE2 + ", " + 
        CMSConstants.ADDRESS_LINE3 + ", " + 
        CMSConstants.ADDRESS_LINE4 + ", " + 
        CMSConstants.ADDRESS_LINE5 + ", " + 
        CMSConstants.ADDRESS_POSTCODE + ", " + 
        CMSConstants.CONTACT_EMAIL + ", " + 
        CMSConstants.CONTACT_EMAIL_DISPLAY + ", " + 
        CMSConstants.CONTACT_EMAIL_SUBJECT + ", " + 
        CMSConstants.CONTACT_TEL + ", " + 
        CMSConstants.CONTACT_TEL_DISPLAY + ", " + 
        CMSConstants.CONTACT_WEB + ", " + 
        CMSConstants.CONTACT_WEB_DISPLAY + ", " + 
        CMSConstants.MODIFICATION_DATE + ", " + 
        CMSConstants.PAGE_HEADER + 
        ") VALUES (" + 
        "?,?,?,?,?,?,?,?,?,?," + 
        "?,?,?,?,?,?,?,?,?,?," + 
        "?,?,?,?,?,?,?,?,?,?," + 
        "?,?,?,?,?,?,?,?,?,?," + 
        "?,?,?);", bindArgs); 

I 어디에 문제가 이해가 안 돼요. 나는 코드를 보았다 "("근처 아무 문제가 없다.

누군가가 나를 도울 수 있기를 바랍니다.

고맙습니다 newone

편집 : 이 내 새 쿼리

this.db.execSQL("UPDATE " + CMSConstants.ITEMS + " SET " + 
       CMSConstants.ID + "= ?, " + 
       CMSConstants.TITLE + " = ?, " + 
       CMSConstants.IS_PAGE + " = ?, " + 
       CMSConstants.IS_HIDDEN + " = ?, " + 
       CMSConstants.ITEM_TYPE + " = ?, " + 
       CMSConstants.ORDER_INDEX + " = ?, " + 
       CMSConstants.SECTION_ID + " = ?, " + 
       CMSConstants.TABLE_SECTION_NAME + " = ?, " + 
       CMSConstants.TABLE_SECTION_ID + " = ?, " + 
       CMSConstants.IMAGE1_FILE + " = ?, " + 
       CMSConstants.IMAGE1_CAPTION + " = ?, " + 
       CMSConstants.IMAGE1_DISPLAY_IN_GALLERY + " = ?, " + 
       CMSConstants.CATEGORY1 + " = ?, " + 
       CMSConstants.CATEGORY2 + " = ?, " + 
       CMSConstants.GEO_LONGITUDE + " = ?, " + 
       CMSConstants.GEO_LATITUDE + " = ?, " + 
       CMSConstants.DESCRIPTION + " = ?, " + 
       CMSConstants.KEYWORDS + " = ?, " + 
       CMSConstants.BLOCKWORDS + " = ?, " + 
       CMSConstants.CLEAN_NAME + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD1_NAME + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD1_VALUE + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD2_NAME + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD2_VALUE + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD3_NAME + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD3_VALUE + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD4_NAME + " = ?, " + 
       CMSConstants.ADDITIONAL_FIELD4_VALUE + " = ?, " + 
       CMSConstants.ADDRESS_LINE1 + " = ?, " + 
       CMSConstants.ADDRESS_LINE2 + " = ?, " + 
       CMSConstants.ADDRESS_LINE3 + " = ?, " + 
       CMSConstants.ADDRESS_LINE4 + " = ?, " + 
       CMSConstants.ADDRESS_LINE5 + " = ?, " + 
       CMSConstants.ADDRESS_POSTCODE + " = ?, " + 
       CMSConstants.CONTACT_EMAIL + " = ?, " + 
       CMSConstants.CONTACT_EMAIL_DISPLAY + " = ?, " + 
       CMSConstants.CONTACT_EMAIL_SUBJECT + " = ?, " + 
       CMSConstants.CONTACT_TEL + " = ?, " + 
       CMSConstants.CONTACT_TEL_DISPLAY + " = ?, " + 
       CMSConstants.CONTACT_WEB + " = ?, " + 
       CMSConstants.CONTACT_WEB_DISPLAY + " = ?, " + 
       CMSConstants.MODIFICATION_DATE + " = ?, " + 
       CMSConstants.PAGE_HEADER + " = ?" 
       , bindArgs); 

이며,이 새로운 오류입니다 :

09-27 09:39:03.105: WARN/System.err(8903): android.database.sqlite.SQLiteConstraintException: error code 19: constraint failed 
09-27 09:39:03.105: WARN/System.err(8903):  at android.database.sqlite.SQLiteStatement.native_execute(Native Method) 
09-27 09:39:03.115: WARN/System.err(8903):  at android.database.sqlite.SQLiteStatement.execute(SQLiteStatement.java:61) 
09-27 09:39:03.115: WARN/System.err(8903):  at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1809) 
09-27 09:39:03.115: WARN/System.err(8903):  at de.enough.appmate.dbase.CMSResource.updateItem(CMSResource.java:1221) 
09-27 09:39:03.115: WARN/System.err(8903):  at de.enough.appmate.dbase.CMSResourceUpdater.updateItems(CMSResourceUpdater.java:178) 
09-27 09:39:03.115: WARN/System.err(8903):  at de.enough.appmate.dbase.CMSResourceUpdater.loadUpdates(CMSResourceUpdater.java:102) 
09-27 09:39:03.115: WARN/System.err(8903):  at de.enough.appmate.dbase.CMSResourceUpdaterRunnable.run(CMSResourceUpdaterRunnable.java:32) 
09-27 09:39:03.115: WARN/System.err(8903):  at java.lang.Thread.run(Thread.java:1019) 
+1

당신이 로그인하고 여기 표시하도록 쿼리를 인쇄 할 수 있습니까? –

+0

@NikitaBeloglazov에 동의합니다. 쿼리를 문자열로 준비하고 Log.d를 실행해야합니다. 이런 식으로 디버그하는 것이 더 쉽습니다. 또한 오류를 보면 제약 조건이 잘못되었습니다 (잘못된 값), 더 이상 SQL 구문 오류가없는 것처럼 보입니다. 당신은 또한 당신의 가치를 확인해야합니다. –

답변

2

이이

this.db.execSQL("UPDATE " + CMSConstants.ITEMS + " SET "+CMSConstants.ID+"="+value) 

내가 당신의 쿼리를 생각하십시오 잘못되었습니다.

,

간단한 업데이트 쿼리

"UPDATE TABLE_NAME SET COLUMN_NAME=COLUMN_VALUE" 
+0

하지만 더 많은 가치가 있습니다. 그럼 내가 어떻게 할거야? – newone

+0

"UPDATE TABLE_NAME SET COLUMN_NAME1 = COLUMN_VALUE1, COLUMN_NAME2 = COLUMN_VALUE2, COLUMN_NAME3 = COLUMN_VALUE3" –

+0

올바른 아이디어가 있다고 생각하지만 newone은 여전히 ​​문자열 연결 대신 자리 표시자를 사용해야하며 작은 따옴표는 SQL 문자열 리터럴의 표준입니다 (SQLite는 큰 따옴표). –

관련 문제