一起Talk Android吧(第二百三十回:Android中的数据存储之数据库五)

本文深入讲解了Android中数据库查询的方法,重点介绍了SQLiteDatabase类的query方法的使用,包括各参数的含义及具体代码示例。

各位看官们大家好,上一回中咱们说的是Android中数据存储之数据库的例子,这一回咱们继续说该例子。闲话休提,言归正转。让我们一起Talk Android吧!

看官们,我们在上一章回中介绍了如何在数据库中删除数据,这一回中我们将介绍如何在数据库中查询数据。查询数据需要使用SQLiteDatabase类的query方法,其函数原型如下:

public Cursor query (String table, String[] columns, String selection, 
               String[] selectionArgs, String groupBy, String having, String orderBy)

该方法是重载方法,一共四个,我们只列举其中的一个方法。此方法中各参数的含义如下:

  • 第一个参数是数据库中表的名字;
  • 第二个参数表示查询的列名;
  • 第三个参数表示查询的行名;
  • 第四个参数表示匹配的内容值;
  • 第五个参数表示查询结果分类的依据;
  • 第六个参数表示分类的依据值;
  • 第七个参数表示查询结果的排序方式,比如升序,降序;

该方法返回Cursor类型的对象。它是一种封装数据的类型,从Cursor中提取出的数据类似Intent,也是使用getInt()等方法,不同之处为方法中不是普通的key,而是表中列的索引,使用cursor.getColumnIndex("name")获取的key,这里的name是表中的列名。另外Cursor也有类似集合中迭代器一样的功能,用于遍历其中的内容。 下面是具体的代码示例,我们在代码中复用了前面章回中SQLiteDatabase类的对象,请大家参考:

//查询数据库Student表中的数据
//没有使用查询条件,因此查找到表中所有的内容
public void  QueryData() {
    Log.i(TAG, "QueryData: ");
    Cursor cursor = mDatabase.query("Student",null , null, null, null, null, null);
    if(cursor.moveToFirst()) {
        do{
            String name = cursor.getString(cursor.getColumnIndex("name"));
            int age = cursor.getInt(cursor.getColumnIndex("age"));
            String className = cursor.getString(cursor.getColumnIndex("class"));
            Log.i(TAG,"Name: "+name+" Age: "+ age +" Class: "+className);
        }while (cursor.moveToNext());
    }
    cursor.close();
}

各位看官,关于Android中数据存储之数据库的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

talk_8

真诚赞赏,手有余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值