Как получить значение поля вместо имени столбца? - PullRequest
2 голосов
/ 21 июля 2011

Я хочу заполнить список данными из курсора следующим образом:

            myCursor = myDBA.getAllCompanies();
    startManagingCursor(myCursor);

    myListAdapter = new SimpleCursorAdapter(this, R.layout.company_row, myCursor, FROM, TO);

    myListAdapter.setViewBinder(VIEW_BINDER);

    companiesListView.setAdapter(myListAdapter);

Я использую пользовательский ViewBinder для заполнения двух TextViews и одного ImageView в каждой строке:

private final ViewBinder VIEW_BINDER = new ViewBinder() {
    /**
     * Binds the Cursor column defined by the specified index to the
     * specified view.
     */
    @Override
    public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
        int viewId = view.getId();
        switch (viewId) {
        case R.id.company_name:
        case R.id.company_desc:
            Log.d(TAG, "Binding TextView");
            TextView venueText = (TextView) view;
            venueText.setText(cursor.getString(columnIndex));
            return true;

        case R.id.company_icon:
            Log.d(TAG, "Binding ImageView");
            ImageView venueIcon = (ImageView) view;
            String iconName;

                iconName = cursor.getString(columnIndex); //Here I get the column name not the field value

            Resources resources = myContext.getResources();
            Drawable drawable = resources.getDrawable(resources
                    .getIdentifier("my.package:drawable/"
                            + iconName, null, null));
            venueIcon.setImageDrawable(drawable);
            return true;
        }
        return false;
    }
};

Моя проблема в том, что вызов метода cursor.getString() возвращает имя столбца, а не значение поля, и поэтому я получаю сотни строк с именами столбцов.

Обновление:

Мой getAllCompanie s включает в себя вызов moveToFirst на Cursor, но все равно я получаю имена столбцов:

public Cursor getAllCompanies(){
    Cursor s = myDB.query(TABLE, KEYS, WHERE, null, null, null, null);
    s.moveToFirst();
    return s;
}

Ответы [ 2 ]

2 голосов
/ 21 июля 2011

Вы пытались переместить курсор к первому индексу cursor.moveToFirst();, затем выполните cursor.getString(columnIndex);?

Есть еще один способ: создать один список или массив, в котором будут храниться значения из курсора, получить доступ ко всем данным внутри него, просматривая курсор

while(cursor.isAfterLast()==false)
{
  list.add(cursor.getString(thestringcollumnindex);
 cursor.moveToNext();
}

тогда просто сделай

iconName=list.get(columnindex);

Это решение не лучшее, но как бы то ни было, служит цели.

0 голосов
/ 16 февраля 2015

Вы пробовали?

 cursor.getString(cursor.getColumnIndex("column_name"));

получит строку из столбца_имя

...