Поиск в базе данных Sqlite с использованием ввода PHP и HTML

РЕДАКТИРОВАТЬ - КОД НИЖЕ ПОКАЗЫВАЕТ ИСПРАВЛЕНИЯ

Мне нужно создать функцию поиска, которая будет искать в базе данных SQLite определенный диапазон дат.

Например:

  • если пользователь введет «7», он будет искать все записи с датой в течение следующих 7 дней.
  • Если пользователь введет «-7», он будет искать все записи за последние 7 дней.

Пока у меня есть:

if (!empty($_POST)) {
    $sql = "SELECT * from table where record_date between date('now') and date('now', :record_date||' days')"; 
    $stmt = $db->prepare($sql);
    $stmt->bindValue(':record_date' , '%'.$webdata['record_date'].'%', SQLITE3_TEXT);
    $result = $stmt->execute();
    while ($row = $result->fetchArray()) { 
        echo '<p>' . htmlspecialchars($row['id'])  . " : " . 
        htmlspecialchars($row['record_date']).'</p>';
    }
}
?>

Похоже, это не приносит никаких результатов.

Если я использую SqliteOnline.com для запроса базы данных, это нормально работает с запросом:

SELECT * from table where record_date between date('now') and date('now', '7 days')

Там синтаксическая ошибка. Слишком много красного кода, поэтому, скорее всего, где-то отсутствует закрывающая цитата

Don't Panic 17.04.2018 18:33

Как сказал @ Don'tPanic, у вас как минимум синтаксическая ошибка. Строка, начинающаяся с $sql = "SELECT * from, не имеет закрывающих двойных кавычек для начинающих.

Dave 17.04.2018 18:40

Мой исходный код содержит заключительную цитату. Это была опечатка, теперь вопрос исправлен. По-прежнему нет результата ..

e90-1992 17.04.2018 20:21
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
3
557
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Закройте котировки $ sql = "ВЫБРАТЬ * из таблицы, где record_date между date ('now') и date ('now', ': record_date days');"

Мой исходный код содержит заключительную цитату. Это была опечатка, теперь вопрос исправлен. По-прежнему нет результата ..

e90-1992 17.04.2018 20:21
Ответ принят как подходящий

Именованные заполнители не следует заключать в кавычки, поскольку в этом случае они интерпретируются как буквальное значение.

Попробуйте изменить:

date('now', ':record_date days')

к:

date('now', :record_date||' days')

Вам также необходимо изменить следующее из:

$stmt->bindValue(':record_date' , '%'.$webdata['record_date'].'%', SQLITE3_TEXT);

к:

$stmt->bindValue(':record_date' , $webdata['record_date'], SQLITE3_TEXT);

Это отлично работает как запрос и дает результаты. Однако он не дает никаких результатов с моими функциями поиска.

e90-1992 19.04.2018 12:11

Другие вопросы по теме