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

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

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

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

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

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

解決済

データベースで取り込んだデータをFragment上に表示したいがアプリに問題が起こる

Haru_T
Haru_T

総合スコア0

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

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

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

1回答

0評価

0クリップ

2985閲覧

投稿2016/09/22 05:26

編集2022/01/12 10:58

単語帳アプリを作っています。
ActivityにFragmentを一つ作り、そこにデータベースより取り込んだデータを表示したいのです。
PupSQLiteを使って作ったSQLiteファイル(assetsフォルダに保存)から読み取ります。
項目が7つあり、それをFragmentに縦に並べたTextViewに表示させたいのです。
特にエラーはありません。ただ処理が間違っているのだと思います。
おかしい点等あればご指摘頂きたいです。

java

package com\.example\.fragmenttest; import android\.database\.Cursor; import android\.database\.SQLException; import android\.database\.sqlite\.SQLiteDatabase; import android\.support\.v4\.app\.FragmentActivity; import android\.support\.v4\.app\.FragmentManager; import android\.support\.v4\.util\.SparseArrayCompat; import android\.support\.v4\.view\.ViewPager; import android\.os\.Bundle; import android\.view\.View; import java\.io\.IOException; public class MainActivity extends FragmentActivity { private DataBaseHelper mDBHelper; private SQLiteDatabase db; private ViewPager mViewPager; private ArrayList<SparseArrayCompat<String>> wList; private static final String DB_TABLE = "WordData"; @Override protected void onCreate\(Bundle savedInstanceState\) { super\.onCreate\(savedInstanceState\); setContentView\(R\.layout\.activity_main\); /\* レイアウトを作る \*/ mViewPager = \(ViewPager\) findViewById\(R\.id\.view_pager\); FragmentManager fm = getSupportFragmentManager\(\); /\* PagerAdapterを作る \*/ PagerAdapter adapter = new PagerAdapter\(fm\); setDatabase\(\); adapter\.addAll\(wList\); mViewPager\.setAdapter\(adapter\); /\* ViewPagerのセット \*/ } public void setDatabase\(\) { mDBHelper = new DataBaseHelper\(this\); SQLiteDatabase database = mDBHelper\.getWritableDatabase\(\); try { Cursor c = db\.query\(DB_TABLE, new String\[\] {"word", "pron", "pronk", "mean1", "mean2", "mean3", "part"}, null, null, null, null, null\); mDBHelper\.createEmptyDataBase\(\); db = mDBHelper\.openDataBase\(\); c\.close\(\); } catch \(IOException ioe\) { throw new Error\("Unable to create database"\); } catch \(SQLException sqle\) { throw sqle; } finally { database\.close\(\); } } }

java

package com\.example\.fragmenttest; import android\.content\.Context; import android\.database\.SQLException; import android\.database\.sqlite\.SQLiteDatabase; import android\.database\.sqlite\.SQLiteException; import android\.database\.sqlite\.SQLiteOpenHelper; import java\.io\.File; import java\.io\.FileOutputStream; import java\.io\.IOException; import java\.io\.InputStream; import java\.io\.OutputStream; public class DataBaseHelper extends SQLiteOpenHelper { private static final String DB_NAME = "WordData\."; private static final String DB_NAME_ASSET = "WordData\.db"; private static final int DB_VERSION = 1; private SQLiteDatabase mDatabase; private final Context mContext; private final File mDatabasePath; private boolean createDatabase = false; public DataBaseHelper \(Context context\) { super\(context, DB_NAME, null, DB_VERSION\); mContext = context; mDatabasePath = mContext\.getDatabasePath\(DB_NAME\); } /\* 空のデータベース作成 \*/ public void createEmptyDataBase\(\) throws IOException { boolean dbExist = checkDatabaseExists\(\); if\(dbExist\) { /\* すでにデータベースが作られている \*/ } else { getReadableDatabase\(\); try { copyDataBaseFromAsset\(\); /\* データベースをコピー \*/ String dbPath = mDatabasePath\.getAbsolutePath\(\); SQLiteDatabase checkDb = null; try { checkDb = SQLiteDatabase\.openDatabase\(dbPath, null, SQLiteDatabase\.OPEN_READWRITE\); } catch\(SQLiteException e\) { } if\(checkDb != null\) { checkDb\.setVersion\(DB_VERSION\); checkDb\.close\(\); } } catch\(IOException e\) { throw new Error\("Error copying database"\); } } } /\* すでにデータベースがあるか確認 \*/ private boolean checkDatabaseExists\(\) { String dbPath = mDatabasePath\.getAbsolutePath\(\); SQLiteDatabase checkDb = null; try { checkDb = SQLiteDatabase\.openDatabase\(dbPath, null, SQLiteDatabase\.OPEN_READWRITE\); } catch\(SQLiteException e\) { } if\(checkDb == null\) { return false; /\* まだ存在していない \*/ } int oldVersion = checkDb\.getVersion\(\); int newVersion = DB_VERSION; if\(oldVersion == newVersion\) { checkDb\.close\(\); /\* データベースは存在していて最新 \*/ return true; } File f = new File\(dbPath\); /\* 最新ではないので削除 \*/ f\.delete\(\); return false; } /\* 格納したデータベースを空のデータベースにコピー \*/ private void copyDataBaseFromAsset\(\) throws IOException { InputStream mInput = mContext\.getAssets\(\)\.open\(DB_NAME_ASSET\); /\* asset内のファイルにアクセス \*/ OutputStream mOutput = new FileOutputStream\(mDatabasePath\); /\* 作成した空のデータベース \*/ byte\[\] buffer = new byte\[1024\]; int size; while\(\(size = mInput\.read\(buffer\)\) > 0\) { mOutput\.write\(buffer, 0, size\); } mOutput\.flush\(\); /\* close the stream \*/ mOutput\.close\(\); mInput\.close\(\); } public SQLiteDatabase openDataBase\(\) throws SQLException { return getReadableDatabase\(\); } public void onCreate\(SQLiteDatabase db\) { } public void onUpgrade\(SQLiteDatabase db, int oldVersion, int newVersion\) { } public synchronized void close\(\) { if\(mDatabase != null\) mDatabase\.close\(\); super\.close\(\); } }

java

package com\.example\.fragmenttest; import android\.graphics\.Color; import android\.os\.Bundle; import android\.support\.v4\.app\.Fragment; import android\.view\.LayoutInflater; import android\.view\.View; import android\.view\.ViewGroup; import android\.widget\.TextView; import org\.w3c\.dom\.Text; /\* 単語情報を表示する Fragment \*/ public class testFragment extends Fragment{ @Override public View onCreateView\(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState\){ Bundle bundle= getArguments\(\); /\* データ取得 \*/ int page = bundle\.getInt\("word"\); String word = bundle\.getString\("word"\); String pron = bundle\.getString\("pron"\); String pronk = bundle\.getString\("pronk"\); String mean1 = bundle\.getString\("mean1"\); String mean2 = bundle\.getString\("mean2"\); String mean3 = bundle\.getString\("mean3"\); String part=bundle\.getString\("part"\); // View をつくる View layout = inflater\.inflate\(R\.layout\.fragment_test, container, false\); TextView wordView =\(TextView\) layout\.findViewById\(R\.id\.word_view\); wordView\.setText\(word\); TextView pronView =\(TextView\) layout\.findViewById\(R\.id\.pron_view\); pronView\.setText\(pron\); TextView pronkView =\(TextView\) layout\.findViewById\(R\.id\.pronk_view\); pronkView\.setText\(pron\); TextView mean1View =\(TextView\) layout\.findViewById\(R\.id\.mean1_view\); mean1View\.setText\(mean1\); TextView mean2View =\(TextView\) layout\.findViewById\(R\.id\.mean2_view\); mean2View\.setText\(mean2\); TextView meaningView =\(TextView\) layout\.findViewById\(R\.id\.mean3_view\); meaningView\.setText\(mean3\); TextView partView =\(TextView\) layout\.findViewById\(R\.id\.part_view\); partView\.setText\(part\); TextView pageView =\(TextView\) layout\.findViewById\(R\.id\.page_view\); pageView\.setText\(String\.valueOf\(page\)\); return layout; } }

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Java

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

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。