169 похожих чатов

Привет! Я пытаюсь понять, как работает кусок кода, где реализовано соединение

с БД по синглтону (взято из phpfaq.ru)
Вот метод:
public static function getConnection($sql, $args = [])
{
$stmt = self::instance()->prepare($sql);
$stmt->execute($args);
return $stmt;
}
Тут вроде всё ясно - надо передавать сам запрос и псевдопеременные.

Хочу передать запрос, где будет псевдопеременная, и пишу следующее:
$sql = 'SELECT * FROM articles ORDER BY id DESC '
. 'LIMIT :count';
$result = Database::getConnection($sql, [':count' => 2]);
(у getConnection вторым аргументом будет переменная с массивом, конечно, но так нагляднее)
Ничего не работает, выдаёт ошибку, т.к отправляется следующий запрос:
SELECT * FROM articles ORDER BY id DESC LIMIT :count

То есть вместо count не ставится 2.
Видимо, я не понял, как работает всё это, протупил над этим почти час.
Как решение - bindParam, но ему тоже нужно передавать значения, если хранить его в getConnection, это становится сложным - я не знаю, как ему передавать параметры - обычными переменными кажется неудобным.
Можете привести пример, как правильно передать псевдопеременные для класса соединения с БД?
Полный код класса на http://phpfaq.ru/pdo/pdo_wrapper#code

2 ответов

8 просмотров

- почему "псевдопеременные"? - почему getConnection не возвращает соединение а выполняет SQL? - http://php.net/manual/ru/book.pdo.php

а если у тебя появятся еще 1, 2, 10 баз?

Похожие вопросы

Обсуждают сегодня

#include <stdio.h> #include <stdlib.h> #include <time.h> void mass_first_generate(int mass[5][7]) {     for (int N = 0; N < 5; N++) {         for (int A = 0; A < 7; A++) {   ...
Чувак
6
https://www.linkedin.com/posts/ugama-benedicta-kelechi-codergirl-103041300_mobiledevelopment-fluttertraining-handsonlearning-activity-7263445699227254784-IdHB?utm_source=share...
CoderGirl
16
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Помогите пожалуйста. Делаю систему плагинов. Проблема сейчас в такая: плагины загружаются в основном потоке. FLibHandle := SafeLoadLibrary(FFileName) Но нужно еще выполнить фу...
Илья 🤣
10
Ну вот просто даже давайте вот как. Какой нибудь конкретный кейс, можете в пример привести, где бч работает и приносит прикладную пользу, а не просто что бы было? Не крипту.
Alexander Andreev
22
объясните пожалуйста, почему функция не работает должным образом? вроде должно брать активное окно сравнивать его размер с размером экрана, и если есть совпадение = true прове...
JF
12
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Гляньте, че бывает: Сегодня по одному проекту одной вебстудии делал проект небольшой, на их хостинге. На Modx revo. В определенный момент , работая в админке, вдруг перестал р...
Artem
7
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
12
> Копаем глубже > Следующий момент был, когда я спросил его, знает ли он JavaScript. Он ответил, что его учили работать с C#. Я тоже в университете писал на C#, но даже там мн...
Oleg Volkov
4
Карта сайта