刚开始接触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