zoukankan      html  css  js  c++  java
  • 单独谈谈 Android Cursor 的使用细节

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

  • 相关阅读:
    python经典算法面试题1.5:如何找出单链表中的倒数第K个元素
    python经典面试算法题1.4:如何对链表进行重新排序
    巧妙利用引用,将数组转换成树形数组
    设计模式学习笔记
    Vue-cli项目部署到Nginx
    设计模式
    设计模式
    springboot原理
    类加载机制-深入理解jvm
    JVM内存调优原则及几种JVM内存调优方法
  • 原文地址:https://www.cnblogs.com/yihujiu/p/6163398.html
Copyright © 2011-2022 走看看