英単語のアプリを作っている最中です。
10問程度のクイズの機能を付けていて、その中で、間違えた単語を自分の苦手な単語として登録できるようにしたいと考えています。
まず間違えたどうこうは置いておいて、出題された10問をすべて登録できるようにしたいのです。
SQLに「check」という項目を設けており、初めはその値が「0」になっています。
そして、update文で出題された単語のその値を「1」にしたいのです。
自分でもか結構調べて基本的な構文の作り方は合っていると思います。しかしエラー文を見る限り、setで「check = 1」が実現できていないようなんです。調べたサイトや参考書とにらみ合いをしても何が違うのか、、、
間違っている部分がどこか分からず非常に困っています。
java
1DataBaseHelper dbhelper = new DataBaseHelper(this); 2final SQLiteDatabase database = dbhelper.getWritableDatabase(); 3 4//addボタンでmywordsに登録する 5 mywords.setOnClickListener(new View.OnClickListener() { 6 @Override 7 public void onClick(View view) { 8 ContentValues values = new ContentValues(); 9 values.put("check","1"); 10 11 for(int i = 9; i < wordlist.size(); i-- ){ 12 //Listの中身が出題順と逆になっているためiを減らしています 13 String word = wordlist.get(i); 14 database.update(TABLE_NAME , values, "word = " + word, null); 15 } 16 add.setText("チェックした単語をmy wordsに登録しました!"); 17 } 18 });
//エラーログ android.database.sqlite.SQLiteException: near "check": syntax error (code 1): , while compiling: UPDATE WordData SET check=? WHERE word = bus at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method) at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:882) at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:493) at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588) at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58) at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31) at android.database.sqlite.SQLiteDatabase.updateWithOnConflict(SQLiteDatabase.java:1563) at android.database.sqlite..update(SQLiteDatabase.java:1514) at com.example.wordcard2.ResultActivity2$1.onClick(ResultActivity2.java:183) at android.view.View.performClick(View.java:4084) at android.view.View$PerformClick.run(View.java:16966) at android.os.Handler.handleCallback(Handler.java:615) at android.os.Handler.dispatchMessage(Handler.java:92) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:4745) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:511) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) at dalvik.system.NativeStart.main(Native Method)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/12/08 07:52
2016/12/08 07:54
2016/12/08 07:56
2016/12/08 08:27
2016/12/08 08:42
2016/12/08 09:12
2016/12/08 09:15