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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

0回答

889閲覧

AutoCompleteTextViewで選択した行のデータではなく最後に登録したデータが表示される

karin10

総合スコア34

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

0クリップ

投稿2020/11/07 02:28

編集2020/11/08 04:39

SQLiteの登録情報の反映をさせたAutoCompleteTextViewでデータ1(列0)の情報を選択して、ボタンを押下すると
textViewに列2、列3、、、と反映されて表示させたいです
しかし、ボタン押下後に表示されるデータが他の行のデータのものになってしまいます。
選択した行のデータを反映させる方法についてご教授お願い致します。

errormsg

1android.database.CursorIndexOutOfBoundsException: Index 11 requested, with a size of 11

pagefragment1

1public class PageFragment1 extends Fragment { 2 3 private String foodName = ""; 4 private int id = 0; 5 private double foodgram = 0.0d; 6 private double calorie = 0.0d; 7 private double protain = 0.0d; 8 private double carbon = 0.0d; 9 private double fat = 0.0d; 10 11@Override 12 public void onViewCreated(View view, Bundle savedInstanceState) { 13 super.onViewCreated(view, savedInstanceState); 14 15 //データベースの取り込み 16 mydb = new MySQLiteOpenHelper(requireActivity()); 17 db = mydb.getReadableDatabase(); 18 final String [] mydata; 19 ArrayList<String> array = new ArrayList<>(); 20 String sql = "SELECT * FROM Products"; 21 Cursor cr = db.rawQuery(sql, null); 22 cr.moveToFirst(); 23 mydata = new String[cr.getCount()]; 24 int i = 0; 25 while (cr.moveToNext()) { 26 27 id = cr.getInt(0); 28 mydata[i] = cr.getString(1); 29 i ++; 30 foodName = cr.getString(1); 31 foodgram = cr.getDouble(2); 32 calorie = cr.getDouble(3); 33 protain = cr.getDouble(4); 34 carbon = cr.getDouble(5); 35 fat = cr.getDouble(6); 36 37 } 38 39 ArrayAdapter<String> adapter = new ArrayAdapter<String>(this.requireActivity(), 40 android.R.layout.simple_dropdown_item_1line, mydata); 41 foodlist1.setAdapter(adapter); 42 foodlist2.setAdapter(adapter); 43 foodlist3.setAdapter(adapter); 44 foodlist4.setAdapter(adapter); 45 46} 47 48 @Override 49 public void onResume() { 50 super.onResume(); 51 52 mydb = new MySQLiteOpenHelper(requireActivity()); 53 db = mydb.getReadableDatabase(); 54 final String [] mydata; 55 ArrayList<String> array = new ArrayList<>(); 56 String sql = "SELECT * FROM Products"; 57 Cursor cr = db.rawQuery(sql, null); 58 cr.moveToFirst(); 59 mydata = new String[cr.getCount()]; 60 int i = 0; 61 do { 62 mydata[i] = cr.getString(1); 63 i ++; 64 }while (cr.moveToNext()); 65 ArrayAdapter<String> adapter = new ArrayAdapter<String>(this.requireActivity(), 66 android.R.layout.simple_dropdown_item_1line, mydata); 67 foodlist1.setAdapter(adapter); 68 foodlist2.setAdapter(adapter); 69 foodlist3.setAdapter(adapter); 70 foodlist4.setAdapter(adapter); 71 } 72 73}

while文の中のcr.get()文を全て削除すると新規データも反映されるのですが、
選択した行のデータの各列の情報をtextViewに反映させたいのでcr.get()文を書いています。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問