我试图在过去一周内从数据库中检索值。现在,我正在运行查询以检索当前时间和当前时间(7天)之间的值。我希望过去1周在条形图中显示数据。因此,以这种方式,我的算法有效。但是,如果我想在星期一查看数据,SQL查询将返回整个上周的值(因为它是今天-7天),因此上周的值也会在图形上弹出。但是我只想从星期日开始查看值。就像,如果我在星期三打开应用程序,它应该向我显示自星期日以来的情节,而不是自上一个星期三以来的情节。我正在寻找一个SQL查询,该查询从星期日开始每周检索一次数据。还是Java具有可以根据日期(例如,每个星期六)触发的功能,以清除数据库中的所有数据,原因是我的代码可以工作。

现在是我的代码:

  public Cursor getStepsWeek(long time_week) throws ParseException{

    String time_past = String.valueOf(new SimpleDateFormat("dd-MM-yyyy ", Locale.getDefault()).format(time_week));
    int ex = Integer.parseInt(time_past.split("-")[0]) - 7;
    String extract = String.valueOf(ex+"-") + String.valueOf(new SimpleDateFormat("MM-yyyy HH:mm", Locale.getDefault()).format(time_week));
    Date date = new SimpleDateFormat("dd-MM-yyyy HH:mm", Locale.getDefault()).parse(extract);

    Log.d("time past",date.getTime()+"");
    SQLiteDatabase liteDatabase = this.getReadableDatabase();
    Cursor cursor = liteDatabase.rawQuery("select * from steps_table where time_steps between " + String.valueOf(date.getTime()) + " and " + (time_week), null);
    return cursor;
}

最佳答案

下定决心您是否需要“过去一个星期”的数据,还是仅需要本周(从星期日开始)的数据。

无论如何,这是用于标识最近的星期日的日期的通用Java代码,如果今天是星期日,则返回今天。

// Get "now"
Calendar cal = Calendar.getInstance();

// Update to most recent "first day of week",  e.g. SUNDAY in the U.S., MONDAY in France
int firstDayOfWeek = cal.getFirstDayOfWeek();
int dayOfWeek = cal.get(Calendar.DAY_OF_WEEK);
if (dayOfWeek < firstDayOfWeek)
    dayOfWeek += 7;
cal.add(Calendar.DAY_OF_MONTH, firstDayOfWeek - dayOfWeek);

// Remove time fields
int year  = cal.get(Calendar.YEAR);
int month = cal.get(Calendar.MONTH);
int day   = cal.get(Calendar.DAY_OF_MONTH);
cal.clear();
cal.set(year, month, day);

// Get a Timestamp for use with PreparedStatement
Timestamp startDate = new Timestamp(cal.getTimeInMillis());

要获得一年的第一天,请使用:
Calendar cal = Calendar.getInstance();
int year = cal.get(Calendar.YEAR);
cal.clear();
cal.set(year, Calendar.JANUARY, 1);
Timestamp startDate = new Timestamp(cal.getTimeInMillis());

07-24 09:49
查看更多