Задать вопрос
@marq

Не выполняется запрос, как правильно его написать?

есть запрос
$result = $connect->query("SELECT * FROM pag WHERE (id='$id' and name='$name') or (id='$id' or name='$name')");

$id и $name передаются аргументами.
почему то, срабатывает только эта часть (id='$id' or name='$name')
  • Вопрос задан
  • 151 просмотр
Подписаться 2 Простой 6 комментариев
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
FanatPHP
@FanatPHP
Чебуратор тега РНР
Либо
SELECT * FROM pag WHERE id=? and name=?
либо
SELECT * FROM pag WHERE id=? or name=?
в текущем виде запрос не имеет смысла.

И для работы с БД надо не пихать переменные прямо в запрос, а использовать плейсхолдеры
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Stimulate
@Stimulate
могу
$result = $connect->query("SELECT * FROM pag 
WHERE 
(
	(id='$id') 
	AND 
	(name='$name')
)
OR 
(
	(id='$id') 
	OR
	(name='$name')
)
");
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽