質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.00%

DBの日付検索について

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 993

yamaiti3

score 23

このようなERRORが出てしまいます。これはどういったERRORなのでしょうか?ご回答お願いします

android.database.sqlite.SQLiteException: unrecognized token: "2018年01月20日" (code 1): , while compiling: SELECT day, time, event FROM person WHERE day =2018年01月20日

        //データを検索
        Button seachButton = (Button) findViewById(R.id.seachButton);
        seachButton.setOnClickListener(new View.OnClickListener() {
                                           ArrayAdapter<String> ad;

                                           @Override
                                           public void onClick(View view) {

                                               SQLiteDatabase db = helper.getReadableDatabase();
                                               Cursor cs = null;


                                                   String[] cols = {"day","time", "event",};
                                                  //String[] params = {searchText.getText().toString()};

                                               //現在日時に初期化
                                               Date dateTime = new Date();

                                               SimpleDateFormat sdf =
                                                       new SimpleDateFormat("yyyy年MM月dd日");
                                               String today = sdf.format(dateTime);



                                                  ad = new ArrayAdapter<String>(
                                                           manage_edit.this,
                                                           android.R.layout.simple_list_item_1);

                                                   cs = db.query("person", cols, "day ="
                                                           +today, null, null, null, null);

                                                   boolean mov = cs.moveToFirst();

                                                   while(mov) {

                                                       int dayd = cs.getColumnIndex("day");
                                                       int timet = cs.getColumnIndex("time");
                                                       int evente = cs.getColumnIndex("event");
                                                       String day = cs.getString(dayd);
                                                       String time = cs.getString(timet);
                                                       String event = cs.getString(evente);
                                                       String ser = day+time + "内容は" + event;

                                                       ad.add(ser);
                                                      ((ListView) findViewById(R.id.list)).setAdapter(ad);

                                                      mov = cs.moveToNext();

                                                   }

                                                   cs.close();
                                                   db.close();
                                               }
                                           });

                //日付設定ダイアログのイベントをインスタンス化
                dateListener =
                        new DatePickerDialog.OnDateSetListener() {
                            //日付設定ダイアログのokボタンがクリックされたときの処理
                            @Override
                            public void onDateSet(
                                    DatePicker view,
                                    int year,
                                    int monthOfYear,
                                    int dayOfMonth
                            ) {
                                //データーをエディットtextに書き込む
                                ((EditText) findViewById(R.id.editDay))
                                        .setText(year + "年" +
                                                (monthOfYear + 1) +
                                                "月" +
                                                dayOfMonth + "日");

                                ((EditText) findViewById(R.id.searchText))
                                        .setText(year + "年" +
                                                (monthOfYear + 1) +
                                                "月" +
                                                dayOfMonth + "日");

                            }
                        };

                //時刻設定のダイアログのイベントリスナーをインスタンス化
                timeListener =
                        new TimePickerDialog.OnTimeSetListener() {
                            @Override
                            public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
                                //データをエディットtextに書き込む
                                ((EditText) findViewById(R.id.editTime))
                                        .setText(hourOfDay + "時" + minute + "分");



                            }
                        };

                ((Button) findViewById(R.id.Button))
                        .setOnClickListener(
                                new View.OnClickListener() {
                                    @Override
                                    public void onClick(View view) {
                                        //現在日時を取得
                                        java.util.Calendar calendar = java.util.Calendar.getInstance();
                                        //日時設定ダイアログのインスタンスを生成
                                        DatePickerDialog dateDialog =
                                                new DatePickerDialog(
                                                        manage_edit.this, dateListener,
                                                        calendar.get(java.util.Calendar.YEAR),
                                                        calendar.get(java.util.Calendar.MONTH),
                                                        calendar.get(java.util.Calendar.DAY_OF_MONTH)
                                                );
                                        //日付設定ダイアログを表示
                                        dateDialog.show();

                                    }
                                }
                        );

                ((Button) findViewById(R.id.Button2))
                        .setOnClickListener(
                                new View.OnClickListener() {
                                    @Override
                                    public void onClick(View view) {
                                        //現在時刻を取得
                                        java.util.Calendar calendar = java.util.Calendar.getInstance();
                                        //時刻設定ダイアログのインスタンスを生成
                                        TimePickerDialog timeDialog =
                                                new TimePickerDialog(
                                                        manage_edit.this,
                                                        timeListener,
                                                        calendar.get(java.util.Calendar.HOUR_OF_DAY),
                                                        calendar.get(java.util.Calendar.MINUTE),
                                                        false
                                                );
                                        //時刻設定ダイアログを表示
                                        timeDialog.show();
                                    }
                                }
                        );
            }
        }
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • unz.hori

    2018/01/19 12:58

    うまくいかないと書いていますが、どううまくいかないのかあいまいです。とりあえず、DBから値が取得できているかを確認してください。コメントアウトしているものを見ると取得結果を見ているように思えますが、その時の結果などを記載するといいと思います。

    キャンセル

  • yamaiti3

    2018/01/20 12:46 編集

    ご返信おそくなり大変申し訳ございません。DBから値を取り出せることはできるのですがたぶん cs = db.query("person", cols,"day = "+ today, null,null,null,null );の部分の現在の日付と登録されたデータと一致しなく登録されたデータと日付があっているか調べる方法が分かりません

    キャンセル

  • unz.hori

    2018/01/22 09:57

    質問時には、環境を詳しく記述してください。内容からAndroid開発でSQLiteを使用しているということは推測できましたが、バージョンの違いによって回答も変わってくることがありますので

    キャンセル

回答 1

checkベストアンサー

+1

とりあえず質問に対しての回答ですが、"2018年01月20日"という語がおかしいよって言ってますね。フォーマットに"年"/"月"/"日"が入ってます。SimpleDateFormat("yyyy-MM-dd");ではどうでしょうか?
参考URL

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/22 17:33

    ご回答ありがとうございました。無事解決いたしました。ありがとうござい枚した

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.00%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる