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

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

ただいまの
回答率

88.59%

AndroidStudioでの日付型データ取得について

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,986

Aies

score 21

現在AndroidStudioの勉強をしようと家計簿アプリを作ろうと思っています。

そこで入力画面でその日買った商品と金額、日付を入力する機能を作ろうと思い、DatePickerDialogを使って日付を選択し、その日付を取得してSQLiteで作ったデータベースに入れたいのですが、data mismatchと出て追加することができません。日付の部分なしで実行したときはエラーがでなかったので、日付の部分でエラーが発生していると思います。

現在の状況としましては、テーブル作成はTEXT型で作成し、EditTextからString型で「2018/12/28」のような形で受け取ってString型でいれようとしています。

調べ方が悪いのか、まったく解決しないので、よろしければご助言をお願いします。

追記
【データベースの構造】
private static final String PRIMARY_KEY = "date";
private static final String COLUMN_CATEGORY = "category";
private static final String COLUMN_PRICE= "price";
private static final String COLUMN_MEMO = "memo";
private static final String _ID = "_id";

private static final String SQL_CREATE_ENTRIES =
"CREATE TABLE " + TABLE_NAME + " (" +
PRIMARY_KEY + " PRIMARY KEY," +
_ID + " INTEGER PRIMARY KEY," +
PRIMARY_KEY + " TEXT," +
COLUMN_CATEGORY + " TEXT," +
COLUMN_PRICE + " INTEGER," +
COLUMN_MEMO + " TEXT)";

【データベースへの追加分】
//オブジェクトを取得
EditText gPrice = (EditText) findViewById(R.id.price);
Spinner gCategory = (Spinner) findViewById(R.id.category);
EditText gMemo = (EditText) findViewById(R.id.memo);
EditText gDate = (EditText) findViewById(R.id.date);

//値を取得
final int price = Integer.parseInt(gPrice.getText().toString());
final String category = (String)gCategory.getSelectedItem();
final String memo = gMemo.getText().toString();
final String date = gDate.getText().toString();

insertData(db, price, category, memo, date);
}

public void insertData(SQLiteDatabase db, int price, String category, String memo, String date){

ContentValues values = new ContentValues();
values.put("date", date);
values.put("memo", memo);
values.put("category", category);
values.put("price", price);

db.insert("kakeibodb", null, values);
}

【エラー文】
E/SQLiteLog: (20) statement aborts at 5: [INSERT INTO kakeibodb(date,memo,category,price) VALUES (?,?,?,?)] datatype mismatch
E/SQLiteDatabase: Error inserting date=2018/12/26 memo=b category=食費 price=8
android.database.sqlite.SQLiteDatatypeMismatchException: datatype mismatch (code 20 SQLITE_MISMATCH)

  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • y_waiwai

    2018/12/28 09:12 編集

    データベースのデータ構造、うまくいかないというコードを提示しましょう
    また、エラーメッセージもそのままの形で提示してください

    キャンセル

  • Aies

    2018/12/28 15:12

    追記いたしました。ご指摘ありがとうございます。

    キャンセル

回答 1

checkベストアンサー

+1

ご提示いただいたコードのSQL_CREATE_ENTRIESをその通り展開すると(TABLE_NAMEが"kakeibodb"なのは推測)、

CREATE TABLE kakeibodb(
    date PRIMARY KEY,
    _id INTEGER PRIMARY KEY,
    date TEXT,
    category TEXT,
    price INTEGER,
    memo TEXT);


このようなSQL文になるのですが、これではテーブルは作成できないはずです。dateというカラムが2箇所ありますし、PRIMARY KEYが2つ設定されていますし。ただ、テーブルが作成できていないのにSQLiteDatatypeMismatchExceptionになるというのも不思議で、示されているコードと実際に動かしているのが違うのではないかと思えます。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/12/29 19:06 編集

    回答ありがとうございます。

    SQLiteではプライマリ宣言と別に型の宣言が必要なのかと勘違いしていました。

    プライマリ2つについては、複合主キーにしたかったのですが、この書き方は違いますか?

    SQLiteをちょこちょこ変えて実行していたので前のキャッシュが残っていたのかもしれません。

    キャンセル

  • 2018/12/29 21:03

    そういう目的ならば、

    CREATE TABLE kakeibodb(
    _id INTEGER,
    date TEXT,
    category TEXT,
    price INTEGER,
    memo TEXT,
    PRIMARY KEY(_id,date));

    のようにすればいいのではないでしょうか。なお、テーブル作成の処理は端末内にデータベースファイルが存在しないときしか走りません。ですから、テーブルの構造を改めたときには、実行前にファイルを削除しておく必要があります。削除方法はファイルの置き場所にもよるのですが、アプリ専用領域に置いているのなら端末操作でアプリのアンインストールを行えば削除されるはずです。

    キャンセル

  • 2018/12/30 12:10

    主キー宣言はそのように書かないといけないんですね。勘違いしていました。

    なるほど、アンインストールが必要なんですね。ありがとうごさいます。
    すみません。今試せる状態にないので、試せるようになったら、試してみようと思います。

    キャンセル

  • 2019/01/04 10:45

    解決しました!ありがとうございました。

    キャンセル

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

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

関連した質問

同じタグがついた質問を見る