如何使用aCursor从数据库中读取一组记录?

问题描述 投票:0回答:1

我有一个sqlite数据库表。我需要从这个表中获取由date列分组的记录。这是我正在运行的查询:

select id as _id,sum(price) as price,sum(quantity) as quantity,sum(quantity*purchase_price) as cost,date from sales where date between '2018-08-24' and '2018-09-01' group by date order by date desc

这应该返回如下:

date            price        quantity        cost

2018-08-24      345          13              250
2018-08-26      425          15              450

这是从按日期分组的查询返回的示例数据。这基本上是一份销售报告,告诉你在2018-08-24你有$345,卖13项目和花$250

我使用游标从查询中收到结果,所以我得到了一个包含所有这些数据的游标对象。我的问题是如何从光标访问所有这些信息?

我尝试使用这样的常规方式访问它:

cursor.getInt(cursor.getColumnIndexOrThrow("quantity"));
cursor.getInt(cursor.getColumnIndexOrThrow("price"));
cursor.getInt(cursor.getColumnIndexOrThrow("cost"));
cursor.getString(cursor.getColumnIndexOrThrow("date"));

但这只会从分组记录中返回第一行。只是第一个!

android sqlite group-by android-cursor
1个回答
0
投票

我认为你错过了光标结果的循环。您可以为结果创建列表,并将光标值放入该列表中。也许这可以帮助你:

if (cursor.moveToFirst()) {

    do{

       //Get_sales_values_from_Cursor

       cursor.getInt(cursor.getColumnIndexOrThrow("quantity"));
       cursor.getInt(cursor.getColumnIndexOrThrow("price"));
       cursor.getInt(cursor.getColumnIndexOrThrow("cost"));
       cursor.getString(cursor.getColumnIndexOrThrow("date"));

       //move_to_next_row
    } while (cursor.moveToNext());
 }    

您甚至可以定义一个列表并将光标值添加到该列表中,这样您就可以在列表中包含所有统计信息。

最好的祝福。

© www.soinside.com 2019 - 2024. All rights reserved.