各位看官们大家好,上一回中咱们说的是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中数据存储之数据库的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!
本文深入讲解了Android中数据库查询的方法,重点介绍了SQLiteDatabase类的query方法的使用,包括各参数的含义及具体代码示例。
8479

被折叠的 条评论
为什么被折叠?



