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

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

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

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

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Android Studio

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

Q&A

解決済

2回答

1929閲覧

SQL文で取り出した変数の使い方

hardmodeLife

総合スコア10

SQLite

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

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Android Studio

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

0グッド

0クリップ

投稿2019/11/06 13:42

編集2019/11/07 13:22

androidアプリを作成しているのですが、SELECT文でデータベースから取り出す処理です。

コード DatabaseHelper helper = new DatabaseHelper(MainActivity.this); SQLiteDatabase db = helper.getWritableDatabase(); try { String sql = "SELECT * FROM houseto WHERE _id = 1"; Cursor cursor = db.rawQuery(sql, null); String note = ""; while (cursor.moveToNext()) { int idxNote = cursor.getColumnIndex("state"); note = cursor.getString(idxNote); } } finally { db.close(); }

ここで取り出した値を変数noteに入れたのですが、ほかのクラス内で変数noteを使用する場合はどのようにすればいいでしょうか。
ちなみにこの変数noteは、非同期処理でURL文字列を作成する際に使用します。

「android studio 引数 クラス間」等で調べてみたりしたのですが、どうもうまくいきませんでした。誰か教えてください。お願いします。ヒントでもいいので何かキーワードを教えてください。

申し訳ありません、まだ勉強し始めて2週間程度なのでちょっとピンときません

コード 非同期処理メソッド{ データベース処理{ データを変数に入れる } 変数を使用する }

このくらいの話なのですが、データベース処理の範囲外の変数は赤字になってしまいます。

とりあえず基礎から本を読み直したほうがいいのはわかりましたが、もう少しヒントをいただけないでしょうか?

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

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

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

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

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

guest

回答2

0

通常はモデルなどにセットして返すものだと思います。
共有と言うより、あくまで結果を返すだけです。
Androidかどうかも関係なく、オブジェクト指向の基礎部分だと思います。

ただ、使い方次第なので「如何様にもできる」というのが回答です。

投稿2019/11/06 13:58

m.ts10806

総合スコア80850

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

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

0

ベストアンサー

追記を確認しました。クラス間ではないですね。
同一クラス内の全てで使いたい場合は、classの直下で変数を定義してください。
※中では定義しないでください。
MainActivityと過程すると以下になります。

java

1public class MainActivity extends Activity { 2 3 String note = ""; 4 5 @Override 6 public void onCreate(Bundle savedInstanceState) { 7 super.onCreate(savedInstanceState); 8 setContentView(R.layout.main); 9 10 11 DatabaseHelper helper = new DatabaseHelper(MainActivity.this); 12 SQLiteDatabase db = helper.getWritableDatabase(); 13 try { 14 String sql = "SELECT * FROM houseto WHERE _id = 1"; 15 Cursor cursor = db.rawQuery(sql, null); 16 while (cursor.moveToNext()) { 17 int idxNote = cursor.getColumnIndex("state"); 18 note = cursor.getString(idxNote); 19 } 20 } finally { 21 db.close(); 22 } 23 24 } 25}

なお、クラス間の場合は以下になると考えます。

私は1項目だけのフラグや文字列などをクラス間で共有したいときは、以下のPreferencesを設定したり読み込んだりして使っています。
下記の例はbooleanですが、Stringなど他の型も扱えます。

但し、元がSQLiteDatabaseなのであれば、それぞれのクラスで読み直しますが。。

java

1 SharedPreferences sharedPreferences; 2 SharedPreferences.Editor editor; 3 4 sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this); 5 editor = sharedPreferences.edit(); 6 7 //フラグ設定 8 boolean questionFlg = true; 9 editor.putBoolean("questionFlg", questionFlg); 10 editor.commit(); 11 12 //フラグ読込 13 questionFlg = sharedPreferences.getBoolean("questionFlg", false);

投稿2019/11/06 17:13

編集2019/11/08 09:05
jun74

総合スコア338

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問