android之ListView中使用的适配器CursorAdapter

本文旨在为初学者介绍如何通过SimpleCursorAdapter简化Android开发中ListView与数据库查询之间的连接过程。重点讨论了如何在ListView中显示数据库查询结果,并提供了实例代码和解决方案,帮助开发者解决在实际项目中遇到的问题。

刚开始接触android的人,估计很多会在ListView这块撞的满头包,因为实在太麻烦了,网上的资料也一大堆,其他的先不说了,这里主要想说的是CursorAdapter类的使用,CursorAdapter主要是ListView用来与数据库查询结构进行连接的适配器,是个虚类,必须自己继承实现,但继承这个适配器还是挺麻烦的,工作量蛮大(至少对于我这种初学者菜鸟来说是这样的),但好像sdk还给我们提供了一个简单类,如果要求不高,比如说只是单行数据显示的话,这个类够用了,相信很多应用也只要用到这个就可以实现了,这个就是SimpleCursorAdapter,这个类是继承的CursorAdapter的,构造函数是这样:

SimpleCursorAdapter(Context context, int layout, Cursor c, String[] from, int[] to)

context:上下文接口

layout:ListView子项布局定义,注意是子项,不是ListView,即item

c:装入的cursor

from:cursor字段名,即查询的数据库字段名,在这里有个比较特别的地方,就是数据库表中必须有一个标示为“_id”的字段,这样返回的cursor才会自动匹配

to:ListView的item中的控件,在前面的layout中必须有定义,以下是我使用的例子

SimpleCursorAdapter listAdapter = new SimpleCursorAdapter(this
             ,R.layout.word_list_item 
             ,cursor
             ,new String[]{"_id"}
             ,new int[]{R.id.tvWordItem});

 

上面讲到,数据库表中必须有"_id"字段,如果建表的时候没想到这个,没有该字段那怎么办呢?可以在查询语句中设置别名解决,下面举例:

select word as _id from listdata where idx like ? or word like ? limit 20


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值