android数据库操作(三)-----用listview显示数据库数据



四、用listview显示数据库数据(效果如下)


1)adapter使用最基本的BasesAdapter

public class SqlActivity extends Activity{
	private ListView lv_db;
	private List<PersonInfo> persons;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.dblist);
		
		PersonDao2 dao = new PersonDao2(this);
		persons = dao.findAll();
		//使用ListView的步骤:
		//1、在xml文件定义一个listView控件,获取控件id
		lv_db = (ListView) findViewById(R.id.lv_db);
		//2、为listview设置adapter
		lv_db.setAdapter(new MyAdapter());
	}
	
	//3、重新定义adapter的类继承BaseAdapter,实现里面未实现的方法,最主要是:getCount()和getView()
	//默认实现类 simpleXXX defaultXXX baseXXX
	private class MyAdapter extends BaseAdapter{
		private static final String TAG = "COCO";

		// getCount()控制listview里面总共有多少个条目
		@Override
		public int getCount() {
			int count = persons.size(); //条目个数=集合的size
			return count;
		}
		@Override
		public Object getItem(int position) {
			return null;
		}
		@Override
		public long getItemId(int position) {
			return 0;
		}
		//getView控制每个条目显示的内容,依据position来控制,传进来的位置是什么就把此位置的view对象给他
		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
		//	Log.i(TAG, "返回的view对象,position"+position);
			//得到某个位置对应的person对象
			PersonInfo info = persons.get(position);
			//视图填充器:inflate ;这个为内部类,要使用上下文则为  类.this
			View view = View.inflate(SqlActivity.this, R.layout.dblist_item, null);
			//一定要在view对象里面寻找孩子的id
			TextView id = (TextView) view.findViewById(R.id.tv_id);
			id.setText("id:"+info.getId()); 
			//上条语句需注意:如果有int类型的值要显示到textview界面上不能使用:id.setText(info.getId());
			//应该要把int值转成字符串:id.setText(info.getId()+"");
			
			TextView name = (TextView) view.findViewById(R.id.tv_name);
			name.setText("姓名:"+info.getName());
			
			TextView number = (TextView) view.findViewById(R.id.tv_number);
			number.setText("电话:"+info.getNumber());
			
			TextView acount = (TextView) view.findViewById(R.id.tv_account);
			acount.setText("收入:"+info.getAccount());
			
			return view ;
		}
	}
}

2)adapter使用ArrayAdapter:

	private static String[] names = { "功能1","功能2","功能3","功能4","功能5","功能6",};
	//this上下文;R.layout.List_item 单个的布局文件里面只有一个textView控件;R.id.tv 控件的id ,所需放置的位置;names 所需放置的内容,此处为names数组
 	 lv_db.setAdapter(new ArrayAdapter<String>(this,R.layout.List_item,R.id.tv,names));

注:

ArrayAdapter适合的需求是可以有图标,但图标只能是一致的;放置一个条目,即一个控件。

ArrayAdapter是继承了BasesAdapter,用起来比较简单


  • 7
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,以下是一个简单的示例代码,演示如何将数据库中的数据显示Android 应用程序的屏幕上。 1. 首先,在 XML 布局文件中添加一个 ListView 控件。 ```xml <ListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 2. 然后,在 Java 代码中创建一个适配器(Adapter)来管理数据并将其绑定到 ListView 控件上。 ```java public class MainActivity extends AppCompatActivity { private ListView listView; private MyAdapter adapter; private List<String> dataList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); listView = findViewById(R.id.listView); dataList = new ArrayList<>(); adapter = new MyAdapter(this, dataList); listView.setAdapter(adapter); // 从数据库中读取数据并添加到 dataList 中 getDataFromDatabase(); } private void getDataFromDatabase() { // 这里假设你已经创建了一个名为 "my_db" 的数据库,并且有一张名为 "my_table" 的表 SQLiteDatabase db = openOrCreateDatabase("my_db", MODE_PRIVATE, null); Cursor cursor = db.rawQuery("SELECT * FROM my_table", null); if (cursor.moveToFirst()) { do { String data = cursor.getString(cursor.getColumnIndex("data")); dataList.add(data); } while (cursor.moveToNext()); } cursor.close(); db.close(); adapter.notifyDataSetChanged(); } } ``` 3. 最后,创建一个自定义的适配器类 MyAdapter,用于将数据绑定到 ListView 控件上。 ```java public class MyAdapter extends BaseAdapter { private Context context; private List<String> dataList; public MyAdapter(Context context, List<String> dataList) { this.context = context; this.dataList = dataList; } @Override public int getCount() { return dataList.size(); } @Override public Object getItem(int position) { return dataList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = LayoutInflater.from(context).inflate(R.layout.list_item, null); TextView textView = view.findViewById(R.id.textView); textView.setText(dataList.get(position)); return view; } } ``` 在这个示例中,我们使用了一个名为 "my_db" 的数据库,并且有一个名为 "my_table" 的表。在实际开发中,你需要根据自己的需求来创建和使用数据库。同时,你也可以根据自己的需要来修改适配器类 MyAdapter 的代码,以满足你的特定需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值