Android StudioでAndroidアプリを開発しています。
現在ShowDatabase.javaでMainActivity.javaのstatic変数であるMainActivity.operateDatabaseを利用しようとしているのですが、
一度MainActivityを呼び出した後に、ShowDatabaseを呼ぶとShowDatabaseでoperateDatabaseが使えているのですが、順番が逆だと呼び出せていません。
どのようにすれば呼び出せますでしょうか。
java
1package to.msn.wings.sanmokunarabe; 2 3import androidx.appcompat.app.AppCompatActivity; 4 5import android.database.Cursor; 6import android.database.SQLException; 7import android.database.sqlite.SQLiteDatabase; 8import android.os.Bundle; 9import android.widget.ListView; 10import android.widget.SimpleAdapter; 11 12import java.util.ArrayList; 13import java.util.Collections; 14import java.util.HashMap; 15 16public class ShowDatabase extends AppCompatActivity { 17 ArrayList<HashMap<String, String>> data = new ArrayList<>(); 18 SQLiteDatabase sqLiteDatabase; 19 20 @Override 21 protected void onCreate(Bundle savedInstanceState) { 22 super.onCreate(savedInstanceState); 23 setContentView(R.layout.activity_show_database); 24 25 String[] columns = {"date", "result"}; 26 if(MainActivity.operateDatabase != null){ 27 if(sqLiteDatabase == null){ 28 sqLiteDatabase = MainActivity.operateDatabase.getReadableDatabase(); 29 } 30 31 Cursor cs = sqLiteDatabase.query("judge", columns, null, null, 32 null, null, null, null); 33 34 cs.moveToFirst(); 35 for (int i = 0; i < cs.getCount(); i++) { 36 HashMap<String, String> row = new HashMap<>(); 37 row.put("date", cs.getString(0)); 38 row.put("result", cs.getString(1)); 39 data.add(row); 40 cs.moveToNext(); 41 } 42 Collections.reverse(data); 43 44 SimpleAdapter simpleAdapter = new SimpleAdapter( 45 this, data, R.layout.list_winlose, 46 columns, 47 new int[]{R.id.date, R.id.result} 48 ); 49 50 ListView list = findViewById(R.id.list); 51 list.setAdapter(simpleAdapter); 52 53 cs.close(); 54 55 } 56 57 } 58}
java
1package to.msn.wings.sanmokunarabe; 2 3import androidx.appcompat.app.AppCompatActivity; 4import androidx.constraintlayout.widget.ConstraintLayout; 5 6import android.content.ContentValues; 7import android.content.Intent; 8import android.database.Cursor; 9 10 11public class MainActivity extends AppCompatActivity { 12 static OperateDatabase operateDatabase; 13 private SQLiteDatabase db; 14 15 @Override 16 protected void onCreate(Bundle savedInstanceState) { 17 super.onCreate(savedInstanceState); 18 setContentView(R.layout.activity_main); 19 20 21 operateDatabase = new OperateDatabase(this); 22 23 if(db == null){ 24 db = operateDatabase.getWritableDatabase(); 25 } 26 27 Cursor c = db.rawQuery("select * from sqlite_master", null); 28 while (c.moveToNext()) { 29 for (int i = 0; i < c.getColumnCount(); i ++) { 30 System.out.print(c.getColumnName(i) + "=" + c.getString(i) + " "); 31 } 32 System.out.println(); 33 } 34 35 } 36 37 38}
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。