使用过 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类,可见出它的设计是基于数据库服务产生的。

最新文章

  1. 锤子OneStep及BigBang使用体验
  2. UIScrollView内容缩放
  3. NSDICTIONARY获取内容的CRASH
  4. 无需操作系统和虚拟机,直接运行Python代码
  5. BZOJ2818: Gcd 欧拉函数求前缀和
  6. C# Linq-Aggregate
  7. 【笔试&amp;面试】C#中的程序集
  8. cn_office2016
  9. Django 创建admin账户
  10. 在Android Studio 上安装Genymotion插件
  11. 为何IntelliJ IDEA比Eclipse更好
  12. 解决GOOGLE无法访问
  13. Docker 下载镜像慢的问题解决方法
  14. python和计算机的交互
  15. Hinge Loss、交叉熵损失、平方损失、指数损失、对数损失、0-1损失、绝对值损失
  16. zookeeper的命令使用
  17. OpenGL学习笔记(6) 基础光照的计算方法
  18. teamviewer and openconnect-gp (globalprotect) in ubuntu
  19. Makefile与Myod
  20. 【刷题】BZOJ 1143 [CTSC2008]祭祀river

热门文章

  1. .Net Core 第三方工具包整理
  2. ural 1119. Metro(动态规划)
  3. 711B - Chris and Magic Square 模拟
  4. php扩展memcache的安装
  5. xp添加右键&quot;打开文件所在位置&quot;
  6. LINUX修改IP地址
  7. webapp 微信开发适配问题
  8. Asp.net中,点击GridView表头实现数据的排序
  9. how to stop a thread
  10. UIView animateWithDuration 使用详解