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

时间:2016-04-24 08:28:27

标签: android sqlite

在我的应用程序中,我试图显示当月的余额,但我无法实现这一目标。

这是我的代码

// 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

2 个答案:

答案 0 :(得分:4)

根据这个link 使用date('now')代替curdate()

为了获取当前日期,在MySQL和SQL Server中,您可以使用CURDATE(),但在SQLite中,您没有此选项。要获取当前日期,您必须在查询中使用date('now')来获取该特定设备中的当前日期。

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

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

答案 1 :(得分:1)

你使用的是SQLite而不是mySQL,所以在SQLite中获取当前日期的函数是

 date('now') 

 datetime('now', 'localtime')

CURDATE()是一个MySQL函数。对于SQLite中不存在的函数Month和Year也是如此。要获得年月和月份,您必须使用:

strftime('%m', myDate)//to get Month

strftime('%Y', myDate)//  to get Year