Android入門:ListView(SimpleCursorAdapter實現)

來源:互聯網
上載者:User

一般ListView都是用來顯示列表的,一般列表的資料都是來自資料庫的,因此我們這裡假設前面已經實現了一個DBService類,裡面存在pageCursorQuery(int offset,int length);

比如dbservice.pageCursorQuery(3,5);表示跳過3個記錄,插入5條記錄,返回Cursor;

pageCursorQuery實現代碼如下,需要注意的是,查詢語句的主鍵必須要重新命名為“_id”,不然會報錯。


public Cursor pageCursorQuery(int low,int high){db = helper.getWritableDatabase();Cursor cursor = db.query("person", new String[]{"id as _id","name","age"}, null, null, null, null, null,low+","+high);return cursor;}

MainActivity.java

package org.xiazdong.db;import org.xiazdong.db.service.DBService;import android.app.Activity;import android.database.Cursor;import android.os.Bundle;import android.widget.ListView;import android.widget.SimpleCursorAdapter;public class MainActivity extends Activity {private ListView listView;@Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main);        listView = (ListView)this.findViewById(R.id.listview);        DBService service = new DBService(this);        Cursor cursor = service.pageCursorQuery(0, 10);        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});        listView.setAdapter(adapter);}}

總結:SimpleCursorAdapter和SimpleAdapter最大的區別就是

(1)前者是用Cursor表示資料,後者用List<Map<String,Object>>表示資料;

(2)前者的查詢語句的主鍵必須要為"_id";

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.