ListView控件-- SimpleCursorAdapter 适配器

SimpleCursorAdapter是以Cursor游标方式传入数据

  1. 上下文对象
  2. 需要绑定到哪个条目界面
  3. 需要传入的Cursor数据
  4. 把data里面key值为name的绑定到R.id.name,以此类推
  5. 需要绑定的条目界面上的哪个控件id,以此类推

listView.setAdapter(adapter); 为listView设置适配器

如果这样直接运行是会报错的,因为SimpleCursorAdapter适配器需要传入的Cursor结果集必须包含有(_id)的字段
两个方式改正:

  1. 把SQL语句用别名返回
  2. 把数据库的主键改成_id,因为只要求Cursor结果集必须包含有(_id)的字段
package com.example.mylistview;

import androidx.appcompat.app.AppCompatActivity;

import android.database.Cursor;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;

import com.example.Service.DBOpenHelper;
import com.example.Service.Person;
import com.example.Service.personService;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    private List<Bean> data=new ArrayList<>();
    private ListView listView;
    private personService service;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        listView=this.findViewById(R.id.listView);

        //数据库
        DBOpenHelper dbOpenHelper=new DBOpenHelper(this);
        dbOpenHelper.getReadableDatabase();
        service=new personService(this,dbOpenHelper);
     
        show2();
    }

    private void show2() {
        //SimpleCursorAdapter是以Cursor游标方式传入数据
        Cursor cursor=service.getCursorScrolld(0,20);
        //如果这样直接运行是会报错的,因为SimpleCursorAdapter适配器需要传入的Cursor结果集必须包含有(_id)的字段
        //两个方式改正:把SQL语句用别名返回
        SimpleCursorAdapter adapter=new SimpleCursorAdapter(this,R.layout.list_item,cursor,
            new String[]{"name","phone","amount"},//把data里面key值为name的绑定到R.id.name,以此类推
            new int[]{R.id.name,R.id.phone,R.id.amount},1); //需要绑定的条目界面上的哪个控件id

        listView.setAdapter(adapter);//为listView设置适配器
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TL。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值