Android: использование SimpleCursorAdapter для получения данных из базы данных в ListView - программирование
Подтвердить что ты не робот

Android: использование SimpleCursorAdapter для получения данных из базы данных в ListView

Я программирую приложение для Android, которое должно использовать базу данных для хранения данных и чтения из нее. Используя этот учебник (на archive.org) У меня есть приложение для создания базы данных, и я могу создавать новые записи, однако я не Не знаете, как читать базу данных, чтобы получить сохраненные данные в 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 был неправильным, поскольку он должен был быть андроидом: list.

4b9b3361

Ответ 1

Используя формат базы данных в учебнике, к которому вы привязались, каждая строка имеет _id, isbn, title и publisher. Теперь предположим, что вы хотите отображать каждый заголовок в ListView:

db = new DBAdapter(this);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
        android.R.layout.simple_list_item_1, 
        db.getAllTitles(), 
        new String[] { "title" }, 
        new int[] { android.R.id.text1 });

ListView listView = (ListView) findViewById(R.id.list);
listView.setAdapter(adapter);

(Вам не нужно прокручивать курсор самостоятельно, адаптер делает это для вас!)

Последние два параметра в вашем конструкторе SimpleCursorAdapter - это то, что вам не хватает. Они являются параметрами "от" и "до":

  • Мы хотим получить имя каждой книги, которая хранится в имени столбца title, здесь мы получаем информацию "от".
  • Далее нам нужно сказать, куда "идти": android.R.id.text1 - это TextView в макете android.R.layout.simple_list_item_1. (Вы можете прорыть свой SDK и сами увидеть файл simple_list_item_1.xml или просто доверять мне на данный момент.)

Теперь оба параметра "from" и "to" являются массивами, потому что мы можем передать более одного столбца информации, попробуйте также этот адаптер:

SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
        android.R.layout.simple_list_item_2, 
        db.getAllTitles(), 
        new String[] { "title", "publisher" }, 
        new int[] { android.R.id.text1, android.R.id.text2 });

С помощью этого адаптера книги в своей базе данных будут отображаться по названию, а затем издателю. Все, что нам нужно было сделать, это использовать макет android.R.layout.simple_list_item_2, который принимает два поля и определяет, какие столбцы отправляются в TextViews.

Надеюсь, это поможет немного. Там еще много чего поучиться, но, возможно, это даст вам некоторые основы.


Последний комментарий

Сверху моей головы, чтобы обновить ListView после добавления новых данных, попробуйте следующее:

public void onClick(DialogInterface dialog, int which) {
    String selection = getResources().getStringArray(R.array.markslist)[which];
    db.insertMark(date, "Default", selection);
    cursor.requery();
    adapter.notifyDataSetChanged();
}

Вам нужно определить adapter и создать переменную для cursor, но это просто:

public class Marks extends ListActivity {
    SimpleCursorAdapter adapter;
    Cursor cursor;
    DBAdapter db = new DBAdapter(this);
    ...

И измените getData() соответственно:

private void getData() {
    cursor = db.getAllMarks();
    adapter = new SimpleCursorAdapter(this, 
            android.R.layout.simple_list_item_1, 
            cursor, 
            new String[] { "value" }, 
            new int[] { android.R.id.text1 });
    ...
}

Удачи!

Ответ 2

Адаптер не используется для каждого элемента в курсоре, один адаптер создается для всего курсора. Вы можете установить этот список для использования этого курсора. Попробуйте некоторые учебные пособия SimpleCursorAdapter, такие как this