使用SQLite从android中选择当前月份的数据

参见英文答案 > MySQL Date and Time functions don’t exist                                    3个
在我的应用程序中,我试图显示当月的余额,但我无法做到这一点.

这是我的代码

// Count Current Month Income
public float CurrentMonthIncome(){
    float x = 0;
    sqliteDatabase db = getReadableDatabase();
    String getamountdata = "SELECT SUM(inc_amount) AS totalInc FROM "+ TABLE_ENTRY + " where year(entry_date)= year(CURDATE()) and MONTH(entry_date)=MONTH(CURDATE())";
    Cursor c = db.rawQuery(getamountdata, null);
    if(c.movetoFirst()){
        x = c.getFloat(0);
    }
    return x;

}

当我执行该代码时,我得到一个例外

E/sqliteLog: (1) no such function: CURDATE
Shutting down VM
FATAL EXCEPTION: main

解决方法:

根据这个link
使用date(‘Now’)而不是curdate().

为了获取当前日期,在MysqLsql Server中,您可以使用CURDATE(),但在sqlite中,您没有此选项.要获取当前日期,您必须在查询中使用日期(“现在”)来获取该特定设备中的当前日期.

所以你的查询将是这样的:

SELECT SUM(inc_amount) AS totalInc 
FROM "+ TABLE_ENTRY + " WHERE strftime('%Y',entry_date) = strftime('%Y',date('Now')) AND  strftime('%m',entry_date) = strftime('%m',date('Now'))

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...