我正在編寫一個android應用程序,該應用程序應該使用數據庫來存儲數據並從中讀取數據。使用this tutorial (on archive.org)我得到了應用程序來創建一個數據庫,我能夠創建新的條目,但是,我不知道如何讀取數據庫以獲取存儲在ListView中的數據。我知道這個網站上有很多類似的問題,但似乎沒有一個適用於教程中的數據庫。Android:使用SimpleCursorAdapter從數據庫獲取數據到ListView
代碼:
import java.util.Calendar;
import maturarbeit.nicola_pfister.studenttools.database.DBAdapter;
import android.app.AlertDialog.Builder;
import android.app.ListActivity;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.database.Cursor;
import android.os.Bundle;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.ListView;
public class Marks extends ListActivity {
DBAdapter db = new DBAdapter(this);
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.marks);
}
@Override
protected void onPause() {
super.onPause();
db.close();
}
@Override
protected void onResume() {
super.onResume();
db.open();
getData();
}
@SuppressWarnings("deprecation")
private void getData() {
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1,
db.getAllMarks(),
new String[] { "value" },
new int[] { android.R.id.text1 });
ListView listView = (ListView) findViewById(R.id.marks_list);
listView.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.marks, menu);
return true;
}
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_add:
Calendar cal = Calendar.getInstance();
int day = cal.get(Calendar.DAY_OF_MONTH);
int month = cal.get(Calendar.MONTH);
final String date = day + "." + month;
Builder builder = new Builder(this);
builder
.setTitle(R.string.dialog_addmarks)
.setItems(R.array.markslist, new OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
@SuppressWarnings("unused")
long id;
String selection = getResources().getStringArray(R.array.markslist)[which];
id = db.insertMark(date, "Default", selection);
}
})
.show();
getData();
break;
case R.id.menu_delete:
//Deleting function yet to be implemented.
break;
}
return super.onOptionsItemSelected(item);
}
}
編輯:ListView控件ID是錯誤的,因爲它必須是機器人:列表。
謝謝。我想我得到了,你想要解釋的是什麼。我用你的適配器,但我仍然得到一個異常,它會崩潰我的應用程序。我認爲錯誤是在別的地方呢? – BlueHazard
複製並粘貼LogCat(使用問題左下角的編輯鏈接)。我會看一看。當您完成此操作時,請在評論中標記我(「@Sam」)。 – Sam
我將LogCat添加到了我的問題中。感謝您的幫助。 – BlueHazard