微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用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'))

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐