Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
21 / 44 / 11
Регистрация: 08.02.2018
Сообщений: 443

Как в bind_param() передать переменные автоматически?

19.03.2018, 09:32. Показов 1067. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, помогите пожалуйста.
У меня есть метод который предназначен для различных SQL запросов.
Этот метод принимает 4 параметра
Sql запрос, email, login, password.
Так вот при добавлении все хорошо, все параметры ставляются на свои места, все работает.
INSERT INTO user (mail,login,pass) VALUES (?,?,?),$this->mail,$this->login,$this->pass

А вот при удалении не работает так как , 2 параметра становятся лишними, и приходится писать новый метод.
DELETE FROM user WHERE id=?,$id



Подскажите пожалуйста как сделать так, чтобы один метод мог делать любые SQL запросы с различными параметрами? И чтобы в bind_param он автоматически вставлялся типы и переменные?


Вот сам скрипт

PHP
1
2
3
4
5
6
7
8
PUBLIC function query($sql,$var1,$var2,$var3) 
{
    $res = $this->link->prepare($sql);
    $res->bind_param('sss',$var1,$var2,$var3);
    return ($res->execute()) true ? false;
    $res->free();
    $this->link->close();
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.03.2018, 09:32
Ответы с готовыми решениями:

PHP 5.4: mysqli_stmt::bind_param() принимает только переменные
Собственно. Какого черта... Вот это - правильно: $aaa = $mysqli->real_escape_string($_POST); $bbb =...

Как в Mathcad автоматически заменить переменные цифрами?
Например, чтобы расписать это: m:=2 n:=3 k:= m+n

Как в Mathcad автоматически заменить переменные цыфрами
Добрый день! Подскажите, пожалуйста такой вопрос: К примеру имеем в Mathcad: x=5 y=10 z=15 x+y+z=30 Как сделать так,...

4
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
19.03.2018, 09:47
1) зачем PUBLIC заглавными?
Цитата Сообщение от maxoun Посмотреть сообщение
($res->execute()) true ? false;
2) Почему всего 1 тернарник, а не 5?
PHP
1
(((((($res->execute()) true ? false) ? true : false) ? true : false) ? true : false) ? true : false)
3) Код после return выполнен не будет
4) php >= 5.6
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public function query($sql, ...$vars) 
{
    $res = $this->link->prepare($sql);
    $types = array_map(
        function ($var) {
            $types = ['integer' => 'i', 'double' => 'd'];
            $type = gettype($var);
            return isset($types[$type]) ? $types[$type] : 's';
        },
        $vars
    );
    $res->bind_param(implode('', $types), ...$vars);
    return $res->execute();
}
1
21 / 44 / 11
Регистрация: 08.02.2018
Сообщений: 443
19.03.2018, 13:01  [ТС]
Цитата Сообщение от Jewbacabra Посмотреть сообщение
зачем PUBLIC заглавными?
1.Так удобно читать.
Цитата Сообщение от Jewbacabra Посмотреть сообщение
2) Почему всего 1 тернарник, а не 5?
Да я забыл там : , а почему 5 туда надо ставить?
Цитата Сообщение от Jewbacabra Посмотреть сообщение
$vars
А его мы не возвращаем просто пишем $vars?
И еще почему Вы поставили ...?

Добавлено через 13 минут
Цитата Сообщение от Jewbacabra Посмотреть сообщение
function ($var)
А имя функции?
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
19.03.2018, 21:23
Лучший ответ Сообщение было отмечено maxoun как решение

Решение

Цитата Сообщение от maxoun Посмотреть сообщение
Так удобно читать.
Очень спорно, да еще и противоречит psr. Слишком много внимания привлекает кричащий текст
Цитата Сообщение от maxoun Посмотреть сообщение
а почему 5 туда надо ставить?

Не по теме:

5 это в мирное время. В военное 10, а по приказу главкома может и до 20 доходить


А если серьёзно, то даже 1 это много. Метод execute и так возвращает true или false.
Цитата Сообщение от maxoun Посмотреть сообщение
А его мы не возвращаем просто пишем $vars?
не понял
Цитата Сообщение от maxoun Посмотреть сообщение
И еще почему Вы поставили ...?
https://secure.php.net/manual/... e-arg-list
Цитата Сообщение от maxoun Посмотреть сообщение
А имя функции?
https://secure.php.net/manual/... nymous.php
1
21 / 44 / 11
Регистрация: 08.02.2018
Сообщений: 443
19.03.2018, 21:31  [ТС]
Jewbacabra, Спасибо, приятно что есть такие люди.

Не смог бы мне помочь, Правильно ли я понимаю работу ООП? в этой теме.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.03.2018, 21:31
Помогаю со студенческими работами здесь

Как сделать так, чтобы локальные переменные не обнулялись автоматически?
Сижу под Linux, использую Code::Blocks, компилятор gcc. Я заметил одну неприятную вещь: когда я где-то забываю что-то обнулить,...

Как передать переменные из url в php?
Имеется такая ссылка uplod/uplod.php?template=template7&Numphotos=33 При нажатии открывается uplod.php..... Нyжно мне передать...

Как передать переменные в метод формы?
В моем случае необходимо передать координаты (int x, int y) в метод формы, не обьявляя их полями, через аргумент это сделать также не...

Как передать переменные из РНР в программу на С++ ?
Как реализовать подобный обмен переменными (хотя бы в теории) ...переменные разных типов, если массив, то его нужно преобразовать для...

Как передать переменные в другой класс?
Всем привет. Не могу передать переменную в другой класс. Буду благодарна, если вы мне объясните в чем проблема. Вот у меня есть класс...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru