【问题标题】:SQLite: Obtaining total of all values in one columnSQLite:获取一列中所有值的总和
【发布时间】:2014-07-31 20:24:54
【问题描述】:

我想创建一个查询,它将在我的 SQLite 数据集的单个列中给出所有值的总和。

我希望此查询位于一个将总数作为 int 返回的方法中,以便我可以在不同的活动中进一步处理它。

我该怎么做?

我已经在我的数据库助手类中创建了类似的方法(见下文),但我不知道如何在 SQLite 中实现查询以给出总数。

在Databasehelper中声明和创建数据库:(我想要总计的列是COL_MED

public class DatabaseHelper extends SQLiteOpenHelper {

    // Database Version
    private static final int DATABASE_VERSION = 10;

    // Database Name
    private final static String DATABASE_NAME = "MeditationDatabase";

    // Contacts table name
    private static final String TABLE_SCORE = "scores";

    // Contacts Table Columns names
    private static final String COL_SESSION = "sessionid";
    private static final String COL_GAMETITLE = "game";
    private static final String COL_NAME = "name";
    private static final String COL_MED = "avgmeditation";
    private static final String COL_MAX = "maxmeditation";
    private static final String COL_AVGATT = "avgattention";
    private static final String COL_MAXATT = "maxattention";
    private static final String COL_SCORE = "score";
    private static final String COL_DATE = "date";

    /**
     * Constructor
     * 
     * @param context
     */
    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    /**
     * Method that creates the database
     */
    @Override
    public void onCreate(SQLiteDatabase db) {

        String CREATE_TABLE_SCORE = "CREATE TABLE " + TABLE_SCORE + "(" + COL_SESSION
                + " STRING PRIMARY KEY, " + COL_GAMETITLE + " STRING, "  + COL_NAME + " STRING, " + COL_MED + " INTEGER, "
                 + COL_MAX + " INTEGER, " + COL_AVGATT + " INTEGER, " + COL_MAXATT + " INTEGER, "  + COL_SCORE +  " INTEGER, " + COL_DATE + " STRING " + ")";
        db.execSQL(CREATE_TABLE_SCORE);

    }

返回数据库中条目数的可能类似方法:

public int getTotalGamesPlayed() {
    SQLiteDatabase db = this.getWritableDatabase();
    try {
        return (int)DatabaseUtils.queryNumEntries(db, TABLE_SCORE);
    } finally {
        db.close();
    }
}

编辑:

这是正确的查询吗:

String query = "SELECT SUM(COL_MED) FROM " + TABLE_SCORE;

【问题讨论】:

    标签: android sql sqlite


    【解决方案1】:

    阅读documentation;您可以使用sum()total()

    列名不是COL_MED;那是符号的名称,其值为列的名称。 与TABLE_SCORE 一样,您必须将其值插入到 SQL 查询中:

    int getSumOfAllAvgMeditations() {
        SQLiteDatabase db = getWritableDatabase();
        try {
            String sql = "SELECT TOTAL(" + COL_MED + ") FROM " + TABLE_SCORE;
            return (int)DatabaseUtils.longForQuery(db, sql, null);
        } finally {
            db.close();
        }
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-11-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多