Android: Справка базы данных - Возврат всех элементов в определенном столбце - PullRequest
0 голосов
/ 17 апреля 2011

Я действительно застрял. Я знаком с разработкой Java и Android, но у меня нет опыта работы с базами данных. Это мой первый раз. Я прошел через несколько уроков, но я не могу понять, как вернуть все значения из определенной строки и установить его в одну строку.

Ниже моя консоль базы данных. Я смог получить все элементы и отобразить их в своем представлении, но я намеревался написать определенную функцию, чтобы что-то делать со всеми данными только в столбце TITLE. Может ли кто-нибудь пролить свет или предоставить небольшую процедуру, чтобы получить все элементы из столбца TITLE в одну строку? Самая последняя функция - мой getTitleList, где я хотел бы собрать данные

Вот функция:

public void getTitleList(){
cursor = db.rawQuery("SELECT TITLE FROM table", null);


cursor.close();

}

Вот мой класс

package edu.asu;

import java.util.ArrayList;

import android.content.ContentValues; импорт android.content.Context; импорт android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; импорт android.os.Bundle; импорт android.view.Menu; import android.view.MenuInflater; импорт android.view.MenuItem; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.AdapterView.OnItemSelectedListener; import android.widget.ListView; import android.widget.SimpleCursorAdapter; импорт android.widget.Toast; импорт android.view.View; import android.app.ListActivity;

импорт статического android.provider.BaseColumns._ID;

открытый класс DbBookConsole расширяет ListActivity {

private static String[] FROM = { _ID, DbConstants.TITLE, DbConstants.PRICE,
        DbConstants.ISBN, DbConstants.CHECKIN };
private DbCreate books;
private static SQLiteDatabase db;
private static int[] TO = { R.id.rowid, R.id.name, R.id.price, R.id.isbn, R.id.checkin};
private ListView lv1;
private static String itemId;
private static String titles;
private static String test;
private Cursor cursor;

static final int BOOK_CANCELED = 0;
static final int BOOK_ADDED = 1;
static final int BOOK_MODIFIED = 2;


@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    showDatabaseContent();


    lv1 = getListView();

    lv1.setTextFilterEnabled(true);

    lv1.setOnItemClickListener(new OnItemClickListener() {

        public void onItemClick(AdapterView<?> a, View v, int position,
                long id) {
            cursor = (Cursor) a.getItemAtPosition(position);
            itemId = cursor.getString(0);
            openOptionsMenu();


        }
    });

    lv1.setOnItemSelectedListener(new OnItemSelectedListener() {

        public void onItemSelected(AdapterView<?> parent, View view,
                int position, long id) {

        }

        public void onNothingSelected(AdapterView<?> arg0) {
            // TODO Auto-generated method stub

        }

    });
}

// selected item index from ListView
public void showDialogItemId(long itemId) {
    Toast.makeText(this,
            "Menu item selected index is" + Long.toString(itemId),
            Toast.LENGTH_LONG).show();

}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.menu, menu);

    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
    case R.id.modifyitem:
        if (null != itemId) {
            Bundle bookToModify = new Bundle();
            bookToModify.putString("cTitle", cursor.getString(1));
            bookToModify.putString("cPrice", cursor.getString(2));
            bookToModify.putString("cISBN", cursor.getString(3));
            bookToModify.putString("cCheckin", cursor.getString(4));

            bookToModify.putString("mod_type", "modifyBook");
            Intent intent = new Intent(this, BookDetails.class);
            intent.setClass(this, BookDetails.class);
            intent.putExtras(bookToModify);
            startActivityForResult(intent, BOOK_MODIFIED);
        } else {
            Toast
                    .makeText(this, "Select Book to modify",
                            Toast.LENGTH_LONG).show();
        }
        break;
    case R.id.additem:

        Intent i = new Intent(this, BookDetails.class);
        Bundle bun = new Bundle();
        bun.putString("mod_type", "addBook");
        i.setClass(this, BookDetails.class);
        i.putExtras(bun);
        startActivityForResult(i, BOOK_ADDED);
        break;
        case R.id.removeitem:
        if (null != itemId) {
            removeBook(itemId);
            showDatabaseContent();
        } else {
            Toast
                    .makeText(this, "Select Book to delete",
                            Toast.LENGTH_LONG).show();
        }
        break;
    }
    return true;
}

@Override
protected void onActivityResult(int requestCode, int resultCode,
        Intent intent) {
    // See which child activity is calling us back.
    switch (resultCode) {

    case BOOK_ADDED:
        // This is the standard resultCode that is sent back if the
        // activity crashed or didn't doesn't supply an explicit result.
        if (resultCode == RESULT_FIRST_USER) {
            Bundle bundle = new Bundle();
            bundle = intent.getBundleExtra("bookData");
            addBook(bundle);
            showDatabaseContent();
        } else {
            Toast.makeText(this, "CANCEL BOOK BUTTON PRESSED",
                    Toast.LENGTH_LONG).show();
        }
        break;
    case BOOK_MODIFIED:
        if (resultCode == 2) {
            Bundle bundle = new Bundle();
            bundle = intent.getBundleExtra("bookData");
            modifyBook(bundle);
            showDatabaseContent();
        } else {
            Toast.makeText(this, "MODIFY BOOK FAILED", Toast.LENGTH_LONG)
                    .show();
        }
        break;
    default:
        break;
    }
}

// method removes item from database
private void removeBook(String itemId) {
    db = books.getWritableDatabase();
    db.delete(DbConstants.TABLE_NAME, "_ID=" + itemId, null);

}

private void addBook(Bundle bundle) {
    // Insert a new record into the Events data source.
    // You would do something similar for delete and update.
    db = books.getWritableDatabase();
    ContentValues vals = new ContentValues();
    vals.put(DbConstants.TITLE, bundle.getString("bookTitle"));
    vals.put(DbConstants.PRICE, bundle.getString("bookPrice"));
    vals.put(DbConstants.ISBN, bundle.getString("bookISBN"));
    vals.put(DbConstants.CHECKIN, bundle.getString("bookCheck"));
    db.insertOrThrow(DbConstants.TABLE_NAME, null, vals);
}

// method should modify existing Contact
private void modifyBook(Bundle bundle) {
    db = books.getWritableDatabase();
    ContentValues vals = new ContentValues();
    vals.put(DbConstants.TITLE, bundle.getString("bookTitle"));
    vals.put(DbConstants.PRICE, bundle.getString("bookPrice"));
    vals.put(DbConstants.ISBN, bundle.getString("bookISBN"));
    vals.put(DbConstants.CHECKIN, bundle.getString("bookCheck"));
    db.update(DbConstants.TABLE_NAME, vals, _ID + "=" + itemId, null);
}

private Cursor getBooks() {
    db = books.getReadableDatabase();
    cursor = db.query(DbConstants.TABLE_NAME, FROM, null, null, null, null, null,
            null);
    startManagingCursor(cursor);
    return cursor;
}

public void showDatabaseContent() {
    books = new DbCreate(this);
    try {
        cursor = getBooks();


        showBooks(cursor);



    } finally {
        books.close();
        db.close();
    }
}

private void showBooks(Cursor cursor) {
    // set up data binding

    SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
            R.layout.item, cursor, FROM, TO);
    setListAdapter(adapter);



}

public void getTitleList () { cursor = db.rawQuery («ВЫБЕРИТЕ НАЗВАНИЕ ИЗ таблицы», пусто);

cursor.close();

} }

1 Ответ

0 голосов
/ 17 апреля 2011

если я не понял вопрос, чтобы получить все элементы из вашего запроса в курсоре, перебрать все элементы и объединить в строку, вы бы сделали что-то вроде этого:

//  constants of column indexes
int INDEX_ROWID = 0; 
int INDEX_TITLE = 1; 

...

db = new MyDBAdapter(this);
db.open();

Cursor c = db.getTitleList();
startManagingCursor(c);

String allTitles;

// loop through cursor 
while(c.moveToNext()) {
    allTitles += c.getString(INDEX_TITLE);
}

Надеюсь, что поможет

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...