Android:计算总和并按月份分组(SQLite)
创始人
2024-10-13 14:00:34
0

要计算总和并按月份分组,可以使用SQLite的GROUP BY子句和SUM函数来实现。下面是一个示例代码:

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

public class MainActivity extends AppCompatActivity {

    private SQLiteDatabase database;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 打开数据库
        database = openOrCreateDatabase("your_database_name", MODE_PRIVATE, null);

        // 创建表格
        database.execSQL("CREATE TABLE IF NOT EXISTS your_table_name (date TEXT, amount REAL)");

        // 插入示例数据
        database.execSQL("INSERT INTO your_table_name (date, amount) VALUES ('2022-01-01', 100.0)");
        database.execSQL("INSERT INTO your_table_name (date, amount) VALUES ('2022-01-02', 200.0)");
        database.execSQL("INSERT INTO your_table_name (date, amount) VALUES ('2022-02-01', 300.0)");
        database.execSQL("INSERT INTO your_table_name (date, amount) VALUES ('2022-02-02', 400.0)");

        // 查询并计算总和并按月份分组
        Cursor cursor = database.rawQuery("SELECT strftime('%Y-%m', date) AS month, SUM(amount) AS total FROM your_table_name GROUP BY month", null);

        // 遍历结果
        if (cursor.moveToFirst()) {
            do {
                String month = cursor.getString(cursor.getColumnIndex("month"));
                double total = cursor.getDouble(cursor.getColumnIndex("total"));
                Log.d("Result", "Month: " + month + ", Total: " + total);
            } while (cursor.moveToNext());
        }

        // 关闭游标和数据库
        cursor.close();
        database.close();
    }
}

上述代码创建了一个名为your_table_name的表格,包含dateamount两个列。示例代码插入了四条数据,其中两条属于1月份,两条属于2月份。

然后使用原生的SQLite查询语句SELECT strftime('%Y-%m', date) AS month, SUM(amount) AS total FROM your_table_name GROUP BY month来计算总和并按月份分组。strftime('%Y-%m', date)函数用于将日期格式化为YYYY-MM的形式。

最后,遍历查询结果并打印每月的总和。

记得在AndroidManifest.xml中添加对应的权限:


这样就可以根据需要计算总和并按月份分组了。

相关内容

热门资讯

今天下午!微乐小程序黑科技免费... 今天下午!微乐小程序黑科技免费,微乐山西脚本插件(透视)都是是有辅助方法(哔哩哔哩)1、该软件可以轻...
透视阶段!wpk私人局辅助是真... 透视阶段!wpk私人局辅助是真的吗(德扑之心透视)总是有辅助方法(哔哩哔哩)1、wpk私人局辅助是真...
复盘辅助挂!微乐小程序免费黑科... 复盘辅助挂!微乐小程序免费黑科技,微乐山西脚本插件(透视)其实是有辅助器(哔哩哔哩)1、这是跨平台的...
透视教材!hhpoker开挂教... 透视教材!hhpoker开挂教程(AApoker安全)总是真的有辅助方法(哔哩哔哩)1、hhpoke...
突发!微信微乐游戏辅助脚本,微... 突发!微信微乐游戏辅助脚本,微信小程序微乐辅助器免费下载(透视)真是真的是有辅助插件(哔哩哔哩)1、...
透视绝活儿!hhpoker开挂... 透视绝活儿!hhpoker开挂教程(HHpoker下载)其实有辅助方法(哔哩哔哩)一、hhpoker...
透视教学!微乐小程序免费黑科技... 透视教学!微乐小程序免费黑科技,微乐小程序黑科技下载(透视)一贯有辅助方法(哔哩哔哩)1、任何透视是...
透视绝活!wpk作必弊(WPK... 透视绝活!wpk作必弊(WPK安卓)好像是有辅助工具(哔哩哔哩)1、在wpk作必弊插件功能辅助器技巧...
此事引发广泛关注!微信微乐游戏... 此事引发广泛关注!微信微乐游戏辅助脚本,微乐智能插件激活码(透视)真是真的是有辅助教程(哔哩哔哩)亲...
透视方式!wepoker轻量版... 透视方式!wepoker轻量版辅助(WePoKer开挂)一直存在有辅助技巧(哔哩哔哩)1、wepok...