• 单独谈谈 Android Cursor 的使用细节

    自带的方法与使用
    服务器君一共花费 85.576 ms 进行了 3 次数据库查询,努力地为您提供了这个页面。
    广告很萌的

    使用过 SQLite 数据库对 Cursor 应该不陌生,这里单独拿出来谈一下,加深对Android SQLite中使用 Cursor 的理解。

    在你理解和使用 Android Cursor 的时候你必须先知道关于 Cursor 的几件事情:

    • Cursor 是每行的集合。
    • 使用 moveToFirst() 定位第一行。
    • 你必须知道每一列的名称。
    • 你必须知道每一列的数据类型。
    • Cursor 是一个随机的数据源。
    • 所有的数据都是通过下标取得。

    Cursor 的一些重要方法:

    • close()  关闭游标,释放资源
    • copyStringToBuffer(int columnIndex, CharArrayBuffer buffer)  在缓冲区中检索请求的列的文本,将将其存储
    • getColumnCount()  返回所有列的总数
    • getColumnIndex(String columnName)  返回指定列的名称,如果不存在返回-1
    • getColumnIndexOrThrow(String columnName)  从零开始返回指定列名称,如果不存在将抛出 IllegalArgumentException 异常。
    • getColumnName(int columnIndex)  从给定的索引返回列名
    • getColumnNames()  返回一个字符串数组的列名
    • getCount()  返回Cursor 中的行数
    • moveToFirst()  移动光标到第一行
    • moveToLast()  移动光标到最后一行
    • moveToNext()  移动光标到下一行
    • moveToPosition(int position)  移动光标到一个绝对的位置
    • moveToPrevious()  移动光标到上一行

    1. 访问 Cursor 的下标获得其中的数据

    cursor.moveToLast();
    last = cursor.getInt(cursor.getColumnIndex("Id"));
    Log.i("nowamagicdb", "last_id=>" + last);
    

    2. 循环 Cursor 取出我们需要的数据

    if (cursor.getCount() > 0) {
    	List<NowaMagic> myList = new ArrayList<NowaMagic>(cursor.getCount());
    	while (cursor.moveToNext()) {
    		myList.add(parse(cursor));
    	}
    	return myList;
    }
    

    当cur.moveToNext() 为假时将跳出循环,即 Cursor 数据循环完毕。

    如果你喜欢用 for 循环而不想用While 循环可以使用Google 提供的几下方法:

    • isBeforeFirst()  返回游标是否指向之前第一行的位置
    • isAfterLast() 返回游标是否指向第最后一行的位置
    • isClosed()  如果返回 true 即表示该游戏标己关闭

    有了以上的方法,可以如此取出数据:

    for(cur.moveToFirst();!cur.isAfterLast();cur.moveToNext())
    {
        int nameColumn = cur.getColumnIndex(People.NAME);
        int phoneColumn = cur.getColumnIndex(People.NUMBER);
        String name = cur.getString(nameColumn);
        String phoneNumber = cur.getString(phoneColumn);
    }
    

    Android 查询数据是通过Cursor 类来实现的。当我们使用 SQLiteDatabase.query()方法时,就会得到Cursor对象, Cursor所指向的就是每一条数据。

    Cursor 位于 android.database.Cursor类,可见出它的设计是基于数据库服务产生的。

更多 推荐条目

Welcome to NowaMagic Academy!

现代魔法 推荐于 2013-02-27 10:23   

本章最新发布
随机专题
  1. [Python程序设计] Django数据库模型 6 个条目
  2. [PHP程序设计] htaccess 设置技巧 6 个条目
  3. [移动开发] Android Studio里的Gradle 3 个条目
  4. [软件工程与项目管理] 呈现器的布局与绘制 11 个条目
  5. [移动开发] Android根基概念Context 8 个条目
  6. [智力开发与知识管理] 信息的类型与结构 9 个条目
  7. [Python程序设计] Python Web部署的背景知识 9 个条目
  8. [PHP程序设计] PHP数组探索 4 个条目
  9. [软件工程与项目管理] 开始使用Git 3 个条目
  10. [Python程序设计] Django架构流程分析 7 个条目
  11. [软件工程与项目管理] 浏览器与CSS渲染技巧 2 个条目
  12. [移动开发] Android属性系统Property 9 个条目
窗口 -- [博客]