AndroidでListViewにエントリを読み込むサンプルSQLiteデータベースを作成しました。クリックすると、各ListViewアイテムが新しいアクティビティを開始してより多くの情報を表示できるようにコードを追加します。このデータベースで別のアクティビティからクエリを実行するにはどうすればよいですか?おかげ別のクラスからSQLiteデータベースにアクセスする
public class Database extends ListActivity {
private final String SAMPLE_DB_NAME = "myFriendsDb";
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ArrayList<String> results = new ArrayList<String>();
SQLiteDatabase db = null;
try {
db = this.openOrCreateDatabase(SAMPLE_DB_NAME, MODE_PRIVATE, null);
db.execSQL("CREATE TABLE IF NOT EXISTS people" +
" (LastName VARCHAR, FirstName VARCHAR," +
" Country VARCHAR, Age INT(3));");
db.execSQL("INSERT INTO people" +
" Values ('Jones','Bob','UK',30);");
db.execSQL("INSERT INTO people" +
" Values ('Smith','John','UK',40);");
db.execSQL("INSERT INTO people" +
" Values ('Thompson','James','UK',50);");
Cursor c = db.rawQuery("SELECT FirstName, LastName FROM people", null);
if (c != null) {
if (c.moveToFirst()) {
do {
String firstName = c.getString(c.getColumnIndex("FirstName"));
String lastName = c.getString(c.getColumnIndex("LastName"));
results.add("" + firstName + " " + lastName);
}while (c.moveToNext());
}
}
this.setListAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,results));
} catch (SQLiteException se) {
Log.e(getClass().getSimpleName(), "Could not create or Open the database");
} finally {
if (db != null)
db.execSQL("DELETE FROM people");
db.close();
}
}
http://www.vogella.com/articles/AndroidSQLite/article.html#databasetutorialは、あらゆる種類のSQLite関連のものに関する素晴らしいチュートリアルです。特に、データベースを開くために使用される 'SQLiteOpenHelper'とデータにアクセスするために使用されるDataSourceクラスを見てください。 – zapl