参见英文答案 > MySQL Date and Time functions don’t exist 3个
在我的应用程序中,我试图显示当月的余额,但我无法做到这一点.
这是我的代码
// Count Current Month Incomepublic 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: CURDATEShutting down VMFATAL EXCEPTION: main
解决方法:
根据这个link
使用date(‘Now’)而不是curdate().
为了获取当前日期,在MysqL和sql 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'))
总结 以上是内存溢出为你收集整理的使用SQLite从android中选择当前月份的数据全部内容,希望文章能够帮你解决使用SQLite从android中选择当前月份的数据所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)