如何在 Android ListView 中显示来自 SQLite 数据库的特定数据

约书亚850

我在 SQLite 数据库中有一个表,它有两个字段,一个是“b”,另一个是“n”,“b”代表书号,“n”代表书名我现在成功获取列表视图中的所有“n”字段我想要当任何用户单击特定列表项时显示我的数据库中的书籍 b 编号,例如,当有人单击 Genesis 时,我有 book n=Genesis,它显示书籍编号,例如 b=1;这里我的代码是一个数据库结构

  */

    public class Bookname extends Fragment {
        private ListView listView;
        private ArrayList<String> stringArrayList;
        private ArrayAdapter<String> adapter;
        private DatabaseHelper mDBHelper;
        private SQLiteDatabase mDb;
       boolean book;

        public Bookname() {
            // Required empty public constructor
        }


        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                                 Bundle savedInstanceState) {
            // Inflate the layout for this fragment
            View view = inflater.inflate(R.layout.fragment_bookname, container, false);

            setData();
            listView = view.findViewById(R.id.list);
            adapter = new ListViewAdapter((MainActivity) getContext(), R.layout.item_listview, stringArrayList);
            listView.setAdapter(adapter);

            listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                @Override
                public void onItemClick(AdapterView<?> parent, View view, int position, long id) {




                }
            });
            return view;
        }

        private void setData() {


            stringArrayList = new ArrayList<>();

            mDBHelper = new DatabaseHelper(getContext());
            mDb = mDBHelper.getReadableDatabase();

            Cursor cursor = mDb.rawQuery("SELECT b, n  FROM key_english;", new String[]{});

            if (cursor.getCount() == 0) {
                Toast.makeText(getContext(), "NO DATA FOUND", Toast.LENGTH_SHORT).show();
            } else {
                while (cursor.moveToNext()) {

                    stringArrayList.add(cursor.getString(1));


                }
            }
        }
    }


Myadopter class


package bible.swordof.God;

import android.app.Activity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import com.amulyakhare.textdrawable.TextDrawable;
import com.amulyakhare.textdrawable.util.ColorGenerator;

import java.util.List;

public class ListViewAdapter extends ArrayAdapter<String> {

    private MainActivity activity;
    private List<String> friendList;

    public ListViewAdapter(MainActivity context, int resource, List<String> objects) {
        super(context, resource, objects);
        this.activity = context;
        this.friendList = objects;
    }

    @Override
    public int getCount() {
        return friendList.size();
    }

    @Override
    public String getItem(int position) {
        return friendList.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder;
        LayoutInflater inflater = (LayoutInflater) activity.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
        // If holder not exist then locate all view from UI file.
        if (convertView == null) {
            // inflate UI from XML file
            convertView = inflater.inflate(R.layout.item_listview, parent, false);
            // get all UI view
            holder = new ViewHolder(convertView);
            // set tag for holder
            convertView.setTag(holder);
        } else {
            // if holder created, get tag from view
            holder = (ViewHolder) convertView.getTag();
        }

        holder.friendName.setText(getItem(position));

        //get first letter of each String item
        String firstLetter = String.valueOf(getItem(position).charAt(0));

        ColorGenerator generator = ColorGenerator.MATERIAL; // or use DEFAULT
        // generate random color
        int color = generator.getColor(getItem(position));

        TextDrawable drawable = TextDrawable.builder()
                .buildRound(firstLetter, color); // radius in px

        holder.imageView.setImageDrawable(drawable);

        return convertView;
    }

    private class ViewHolder {
        private ImageView imageView;
        private TextView friendName;

          public ViewHolder(View v) {
            imageView = (ImageView) v.findViewById(R.id.image_view);
            friendName = (TextView) v.findViewById(R.id.text);
        }
    }
}



[My database structure][1]


  [1]: https://i.stack.imgur.com/7aXut.png

迪内什·辛加迪亚

创建模型如:

public class BookData {

private String bookNo;
private String bookName;

BookData(String bookNo, String bookName){
    this.bookNo = bookNo;
    this.bookName = bookName;
}

public String getBookNo() {
    return bookNo;
}

public void setBookNo(String bookNo) {
    this.bookNo = bookNo;
}

public String getBookName() {
    return bookName;
}

public void setBookName(String bookName) {
    this.bookName = bookName;
} }

创建 ArrayList 对象,如:

ArrayList<BookData> stringArrayList = new ArrayList<>();

将数据存储在模型中

stringArrayList.add(new BookData(cursor.getString(0),cursor.getString(1)));

并使用以下方法检索数据:

listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                 String bookNo = stringArrayList.get(position).getBookNo();
                 Log.e("BookNo : ", bookNo);
            }
        });

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

如何在Android的ListView中显示sqlite数据库的结果?arrayadapter有可能吗?或cursoradapter?

ListView Android 中的 SQLite 数据库

Android如何从onListItemClick中获取ListView ID并使用它?ListView,通知,SQLite数据库

从Android中先前创建的SQLite数据库中搜索和检索特定数据?

如何在android中读取特定的消息格式并存储在sqlite数据库中?

如何在android sqlite中更新数据库表?

如何在android的Sqlite数据库中创建表

如何在android中对sqlite数据库进行排序

如何从 ListView 和 SQLite 数据库中删除项目?

Android Eclipse如何从phpMySql数据库显示特定数据到列表视图

如何在主页“GridView”布局中显示来自 SQLite 数据库的数据

如何在Android中从SQLite填充ListView?

SQLite数据库C#Android中的Xamarin ListView显示项目

从Java中的SQLIte数据库检索特定数据

Android在SQlite数据库中存储Listview数据,并在Listview中创建活动时检索数据

如何在Android中更新现有sqlite数据库中的数据

如何在Android Studio上获取Sqlite数据库中插入数据的实时视图

Android Studio,如何从Sqlite数据库中检索数据并将其显示到textview中?

从SQLite数据库检索图像并在ListView中显示

ListView不显示存储在SQLite数据库中的项目

Android:在gridview中而不是在listview中显示来自远程数据库的数据(将ListView转换为GridView)

Android Studio:使用 ListView 显示 SQLite 数据库行的 ArrayList

如何在微调器中显示来自sqlite的数据

在Android上的ListView中显示数据库中的数据

如何从Android中的SQLite数据库获取名称

如何使用cursorloader读取Android中的SQLite数据库?

如何从Android中的SQLite数据库获取空值

在Android中首次使用SQLite数据库。如何?

Android如何从SQLite数据库的列中获取值