3

我正在尝试从 SQLITE 中检索列的总和。我能够成功地得到它。但是当我尝试只检索 10 行的总和时,它会再次返回整列的总和。该查询似乎是正确的。

public String getUnitsForWeek(Context context) throws IOException {
    DataBaseHelper dbHelper = new DataBaseHelper(context);

    String query = "SELECT sum(UNITS) FROM SERVICE_TABLE order by id DESC limit 7";
    return String.valueOf(dbHelper.getString(query));

}

dbHelper.getString 方法是:

public int getString(String query) {
    String mypath = DB_PATH + DB_NAME;
    SQLiteDatabase database = SQLiteDatabase.openDatabase(mypath, null, 
            SQLiteDatabase.OPEN_READWRITE);
    Cursor cursor = null;

    int i;

    cursor = database.rawQuery(query, null);


    cursor.moveToFirst();
    i= cursor.getInt(cursor.getColumnIndex(cursor.getColumnName(0)));
    return i;

}

谢谢。

4

2 回答 2

8

SUM是一个聚合函数,它将多行数据合并为一个。由于只有一个结果行,LIMIT并且ORDER BY没有意义。

UNITS要对具有最高的 7 行求和ID,您可以使用子选择:

SELECT SUM(UNITS) FROM (SELECT UNITS FROM SERVICE_TABLE ORDER BY id DESC LIMIT 7);
于 2013-09-11T13:08:38.737 回答
3

你不能做一个副选吗?

SELECT sum(UNITS) FROM (SELECT UNITS FROM SERVICE_TABLE order by id DESC limit 7) s
于 2013-09-11T13:06:22.420 回答