如何在 sqlite android 中检索下一个值

How to retrieve the next value in sqlite android

您好,我有一个可以显示学生姓名和性别的应用程序。在我的查询中,我将显示限制为 20。我将如何通过单击下一步按钮来应用 21-40 的显示。如果我点击上一个,它也会返回。

MainActivity class

public class MainActivity extends Activity {

    List<Students> GetAll;
    DatabaseHelper db = new DatabaseHelper(this);
    ListView lv;
    Context context = this;
    DatabaseHelper dbhelper;
    Button btnprevious,btnnext;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        dbhelper = new DatabaseHelper(MainActivity.this);
        //Add below lines to your original code
        try{
            dbhelper.createDataBase();
        }
        catch(IOException e){
            e.printStackTrace();
        }
        try {
            dbhelper.openDataBase();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        //Till here
        GetAll = dbhelper.getAll();
        lv = (ListView) findViewById(R.id.list);
        lv.setAdapter(new ViewAdapter());
    }



    public class ViewAdapter extends BaseAdapter {

        LayoutInflater mInflater;

        public ViewAdapter() {
            mInflater = LayoutInflater.from(context);
        }

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

        @Override
        public Object getItem(int position) {
            return null;
        }

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

        @Override
        public View getView(final int position, View convertView, ViewGroup parent) {

            if (convertView == null) {
                convertView = mInflater.inflate(R.layout.list_item,null);
            }

            final TextView names = (TextView) convertView.findViewById(R.id.doctorlist_name);
            final TextView gender = (TextView) convertView.findViewById(R.id.doctorlist_gender);

            names.setText(GetAll.get(position).getname());
            gender.setText(GetAll.get(position).getgender());

            return convertView;
        }
    }
}

DatabaseHelper class

public List<Students> getAll() {

        final int maxCount = 20;

        List<Students> sList = new ArrayList<Students>();
        {
            String selectQuery =
                    "SELECT id,full_name,gender FROM students LIMIT " +maxCount+" ";
            Log.e("students query: ", selectQuery);
            SQLiteDatabase db = this.getWritableDatabase();
            Cursor cursor = db.rawQuery(selectQuery, null);

            // looping through all rows and adding to list
            if (cursor.moveToFirst()) {
                do {
                    Students si = new Students();
                    si.setid(Integer.parseInt(cursor.getString(0)));
                    si.setname(cursor.getString(1));
                    si.setgender(cursor.getString(2));

                    sList.add(si);
                } while (cursor.moveToNext());
            }
            db.close();
        }
        return sList;
    }

在单击下一个按钮时将索引增加 20,在单击上一个按钮时将索引减少到 20,您可以通过以下查询实现。

String selectQuery = "SELECT id,full_name,gender FROM students LIMIT 20, "+index;

编辑:

public List<Students> getStudent(int index) {
        final int maxCount = 20;
        List<Students> sList = new ArrayList<Students>();{
            String selectQuery = "SELECT id,full_name,gender FROM students LIMIT "+maxCount+", "+index;;
            Log.e("students query: ", selectQuery);
            SQLiteDatabase db = this.getWritableDatabase();
            Cursor cursor = db.rawQuery(selectQuery, null);
            // looping through all rows and adding to list
            if (cursor.moveToFirst()) {
                do {
                    Students si = new Students();
                    si.setid(Integer.parseInt(cursor.getString(0)));
                    si.setname(cursor.getString(1));
                    si.setgender(cursor.getString(2));

                    sList.add(si);
                } while (cursor.moveToNext());
            }
            db.close();
        }
        return sList;
}



private int currentPageIndex=0; 
@Override
public void onClick(View view) {
     switch(view.getId()){
          case R.id.prevBtn;
                currentPageIndex -=20;
                GetStudent.clear();
                GetStudent.addAll(dbhelper.getStudent(int index));
                adapter.notifyDataSetChanged();
        break;
          case R.id.nextBtn;
                currentPageIndex +=20;
                GetStudent.clear();
                GetStudent.addAll(dbhelper.getStudent(int index));
                adapter.notifyDataSetChanged();
        break;
     }
}

您可以更改 whereCluse: 例如下一页:(page = 2) id> 20*(page - 1) and LIMIT 20*(page)