Android入门:ListView(SimpleCursorAdapter实现)

http://blog.csdn.net/xiazdong/article/details/7705908


一般ListView都是用来显示列表的,一般列表的数据都是来自数据库的,因此我们这里假设前面已经实现了一个DBService类,里面存在pageCursorQuery(int offset,int length);

比如dbservice.pageCursorQuery(3,5);表示跳过3个记录,插入5条记录,返回Cursor;


pageCursorQuery实现代码如下,需要注意的是,查询语句的主键必须要重命名为“_id”,不然会报错。


[java]  view plain  copy
  1. public Cursor pageCursorQuery(int low,int high){  
  2.     db = helper.getWritableDatabase();  
  3.     Cursor cursor = db.query("person"new String[]{"id as _id","name","age"}, nullnullnullnullnull,low+","+high);  
  4.     return cursor;  
  5. }  

MainActivity.java


[java]  view plain  copy
  1. package org.xiazdong.db;  
  2.   
  3. import org.xiazdong.db.service.DBService;  
  4.   
  5. import android.app.Activity;  
  6. import android.database.Cursor;  
  7. import android.os.Bundle;  
  8. import android.widget.ListView;  
  9. import android.widget.SimpleCursorAdapter;  
  10.   
  11. public class MainActivity extends Activity {  
  12.     private ListView listView;  
  13.     @Override  
  14.     public void onCreate(Bundle savedInstanceState) {  
  15.         super.onCreate(savedInstanceState);  
  16.         setContentView(R.layout.main);  
  17.         listView = (ListView)this.findViewById(R.id.listview);  
  18.         DBService service = new DBService(this);  
  19.         Cursor cursor = service.pageCursorQuery(010);  
  20.         SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.item,cursor, new String[]{"_id","name","age"}, new int[]{R.id.id1,R.id.name,R.id.age});  
  21.         listView.setAdapter(adapter);  
  22.     }  
  23. }  

总结:SimpleCursorAdapter和SimpleAdapter最大的区别就是

(1)前者是用Cursor表示数据,后者用List<Map<String,Object>>表示数据;

(2)前者的查询语句的主键必须要为"_id";

5
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值