SQLite выбирают все отчеты на сегодняшний день и в предыдущий день

У меня есть следующая таблица в моей базе данных:

    database.execSQL("create table " + TABLE_LOGS + " (" 
            + COLUMN_ID + " integer primary key autoincrement," 
            + COLUMN_ID_DAY_EXERCISE + " integer not null,"
            + COLUMN_REPS + " integer not null,"
            + COLUMN_WEIGHT + " real not null,"
            + COLUMN_1RM + " real not null,"
            + COLUMN_DATE + " integer not null"
            + ")");

Я храню метку времени Unix в области COLUMN_DATE (целое число).

Теперь у меня есть следующая функция, которая захватывает все отчеты:

public Cursor fetchCurrentLogs(long dayExerciseDataID) {
   //where day = today
    Cursor cursor = database.rawQuery("select " + MySQLiteHelper.COLUMN_ID + "," + MySQLiteHelper.COLUMN_REPS + ", " + MySQLiteHelper.COLUMN_WEIGHT + " " +
            "from " + MySQLiteHelper.TABLE_LOGS + " " +
            "where " + MySQLiteHelper.COLUMN_ID_DAY_EXERCISE + " = '" + dayExerciseDataID + "'", null);
    if (cursor != null) { cursor.moveToFirst(); }
    return cursor;
}

Теперь то, что я хочу сделать, я хочу заставить эту функцию только захватить отчеты на сегодняшний день.

Тогда я хочу сделать другую функцию точно тем же самым, однако вместо того, чтобы получить отчеты на сегодняшний день, я хочу, чтобы он получил отчеты в течение предыдущего дня. Предыдущим я имею в виду новый день, у которого есть отчеты, который не является сегодня. Таким образом, это могло быть вчера, или 3 дня назад, или месяц назад.

Я знаю в MySQL, можно сделать что-то вроде этого в течение текущего дня:

, где date_format (from_unixtime (COLUMN_DATE), '%Y-% m-% d') = date_format (теперь (), '%Y-% m-% d')

Что эквивалент к этому для SQLite?

Кроме того, кто-либо может помочь мне с где пункт в течение предыдущего дня, как упомянуто выше?

Большое спасибо.

6
какова стоимость в COLUMN_DATE? это находится в метке времени Unix?
добавлено автор Nabeel K, источник

5 ответы

String sql = "SELECT * FROM myTable WHERE myDate >= date('now','-1 day')"; 
Cursor mycursor = db.rawQuery(sql);

ОТРЕДАКТИРУЙТЕ:

SELECT * from Table1 where myDate = (select max(myDate) from Table1 WHERE myDate < DATE('now') )
15
добавлено
Я должен только выбрать отчеты в течение предыдущего дня, не всех предыдущих дней. Знайте то, что я имею в виду? Так позволяет, говорят, что у меня есть записи в базе данных на сегодняшний день, и 3 дня назад, и 6 дней назад, я хочу, чтобы одна функция заставила отчеты на сегодняшний день и другую функцию получать отчеты для 3 дня назад.
добавлено автор scarhand, источник
ваш редактировать работавший потрясающий.thank you!
добавлено автор scarhand, источник
Привет я должен принести отчеты прошлых 5 минут текущей даты тогда, как я могу достигнуть этого? @Yaqub
добавлено автор Riddhi Shah, источник

Посмотрите документация функций даты/времени:

SELECT *
FROM MyTable
WHERE myDate >= date('now', '-1 days')
  AND myDate <  date('now')
3
добавлено

Не делайте преобразования в своем SQL-операторе. Сделайте преобразование в своем Явском методе. Имейте свой Явский метод, создают полный SQL-оператор. Все, в чем вы нуждаетесь, является функцией, чтобы преобразовать Явский DateTime в формат Unix.

Cursor cursor = database.rawQuery("select " + MySQLiteHelper.COLUMN_ID + "," + MySQLiteHelper.COLUMN_REPS + ", " + MySQLiteHelper.COLUMN_WEIGHT + " " +
            "from " + MySQLiteHelper.TABLE_LOGS + " " +
            "where " + MySQLiteHelper.COLUMN_ID_DAY_EXERCISE + " = '" + dayExerciseDataID + 
            " OR " + MySQLiteHelper.COLUMN_ID_DAY_EXERCISE + " = '" + previousDay(dayExerciseDataID) +
"'", null);

Просто необходимо создать это previousDay метод.

2
добавлено

Может быть Он, слишком позднее, но, это может помочь кому-то. Я не делаю по-другому как предыдущие разработчики, я просто хотел поместить свою версию, и вероятно это даже не является лучшим...

    String selectQuery = "SELECT * FROM "+Your_table+" 
WHERE ("+Column_1+" = "+Value_For_Column1+" AND date("+Your_Column_With_Time_Values+") == date('now')) AND 

"+Some_Other_Column+" = "+Some_Other_Value+" OR "+Some_Other_Column+" = "+Some_Other_Value+" ORDER BY "+Your_Column+" DESC";

Если могла бы быть некоторая ошибка, это могло бы произойти легко из-за конкатенации строк. Спасибо!!

0
добавлено

Может быть Он, слишком позднее, но, это может помочь кому-то. Я не делаю по-другому как предыдущие разработчики, я просто хотел поместить свою версию, и вероятно это даже не является лучшим...

    String selectQuery = "SELECT * FROM "+Your_table+" 
WHERE ("+Column_1+" = "+Value_For_Column1+" AND date("+Your_Column_With_Time_Values+") == date('now')) AND 

"+Some_Other_Column+" = "+Some_Other_Value+" OR "+Some_Other_Column+" = "+Some_Other_Value+" ORDER BY "+Your_Column+" DESC";

Если могла бы быть некоторая ошибка, это могло бы произойти легко из-за конкатенации строк. Спасибо!!

0
добавлено
Mobile Dev Jobs — вакансии и аналитика
Mobile Dev Jobs — вакансии и аналитика
6 187 участник(ов)

Публикуем вакансии и запросы на поиск работы по направлению iOS, Android, Xamarin и т.д. ВАЖНО: Правила публикации и правила канала: Ссылка – https://telegra.ph/Pravila-oformleniya-vakansij-i-rezyume-11-09-2

Android Developers
Android Developers
4 476 участник(ов)

Общаемся на темы, посвященным Android-разработке, SDK, Kotlin, Realm и т.д.

Android Architecture
Android Architecture
2 186 участник(ов)

Русскоязычный чат по архитектуре в андроид приложениях. Подробнее: http://telegra.ph/Android-Architecture-12-24

rus-speaking/android
rus-speaking/android
1 705 участник(ов)

Основной чат по Android разработке (вопрос-ответ). ПРАВИЛА: bit.ly/andr-rules. NEWS: bit.ly/AnrdResId ЧАТЫ: Основной: bit.ly/andr-main IDE, сборка, Git, сервисы: bit.ly/andr-tools Оффтоп: bit.ly/andr-offtop Конференции, события: bit.ly/andr-events Вакансии, найм: bit.ly/andr-job Архитектура: bit.ly/andr-patterns Rx: bit.ly/andr-rx Тестирование: bit.ly/andr-test Kotlin: bit.ly/andr-kotlin Хаmarin: bit.ly/andr-xamarin За мат, спам, агрессию, предложения о работе, оффтоп в этом канале - бан на сутки и более ☢☢☢

Android Dev Подкаст
Android Dev Подкаст
1 325 участник(ов)

Комната для обсуждения Android Dev подкаста apptractor.ru/AndroidDev/ Общее обсуждение Android: https://t.me/android_ru Остальные чаты про Android: http://t.me/devChats Наши новости https://t.me/androiddevpodcast_news

SqlCom.ru - Стиль жизни SQL
SqlCom.ru - Стиль жизни SQL
908 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только MS SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz). Предложения в @sql_ninja

Android Guards
Android Guards
602 участник(ов)

Обсуждение любых вопросов касающихся безопасности Android. - Защита системы и приложений - Уязвимости и эксплойты - Вредоносное ПО - Копание в кишках системы и приложений (RE)

Android JOB
Android JOB
466 участник(ов)

Публикуем вакансии и запросы на поиск работы по направлению Android (full-time, part-time, remote и разовые подработки)

AndroidDev :: Разработка. It's Android time now!
AndroidDev :: Разработка. It's Android time now!
458 участник(ов)

It's Android time now! Чат разработчиков Android. Вакансии, резюме и информацию о митапах размещать можно. Публикацию скрытой и явной рекламы ваших каналов и сайтов после получения разрешения от @olegushakov

SQL_Ninja
SQL_Ninja
340 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz)

Aandroid Talks!
Aandroid Talks!
212 участник(ов)

Чат об общих вопросах по ОС Android. Чат для разработки под андроид - pro.android: https://t.me/joinchat/AAAAAEKIFKnmRT9cMebb9w

Android Rus
Android Rus
68 участник(ов)