Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: mysqli обертка

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: ---
madlabel
Отправлено: 21 Марта, 2016 - 14:46:52
Post Id


Новичок


Покинул форум
Сообщений всего: 45
Дата рег-ции: Июль 2015  


Помог: 0 раз(а)




Понравилась обертка, но на ней лежат авторские права скрипта simpla cms.
Имеется ли подобное детище? Обыскался уже.

Пример обертки от симплы:
Спойлер (Отобразить)


Примеры запросов:
.... $db->placehold(SELECT * FROM __table WHERE id = ? AND name = ?, 1, Misha);
.... $db->placehold(SELECT * FROM __cities WHERE region_id = ?, array('id' = 1, 'id' = 2));

(Отредактировано автором: 21 Марта, 2016 - 14:52:09)

 
 Top
OrmaJever Модератор
Отправлено: 21 Марта, 2016 - 16:08:16
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




и что в ней удивительного? чистый mysql умеет так же


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
madlabel
Отправлено: 21 Марта, 2016 - 18:00:12
Post Id


Новичок


Покинул форум
Сообщений всего: 45
Дата рег-ции: Июль 2015  


Помог: 0 раз(а)




OrmaJever пишет:
и что в ней удивительного? чистый mysql умеет так же


Понятно, что и с обычными запросами тоже можно работат, без плейсхолдеров. Но именно в данной реализации нравятся плейсхолдеры. Посмотрел подобные библиотеки, мало их, и все не то. Хотелось бы что-то подобное.
 
 Top
OrmaJever Модератор
Отправлено: 21 Марта, 2016 - 19:57:06
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




madlabel пишет:
Но именно в данной реализации нравятся плейсхолдеры

Чем?? Чем они отличаются от стандартных?
madlabel пишет:
$db->placehold(SELECT * FROM __table WHERE id = ? AND name = ?, 1, Misha);

вот так это выглядит в mysqli
PHP:
скопировать код в буфер обмена
  1. $p = $mysqli->prepare('SELECT * FROM __table WHERE id = ? AND name = ?');
  2. $p->bindParam('is', 1, 'Misha');
  3. $p->execute();
  4.  

Если хотите в одну строку то создайте простенькую функцию, но я думаю в этом нет необходимости


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
madlabel
Отправлено: 22 Марта, 2016 - 18:40:04
Post Id


Новичок


Покинул форум
Сообщений всего: 45
Дата рег-ции: Июль 2015  


Помог: 0 раз(а)




Так так, не могу победить..

PHP:
скопировать код в буфер обмена
  1.  
  2.         public function query($query){
  3.         if ($query = $this->mysqli->prepare($query)) {
  4.             if (func_num_args() > 1) {
  5.                 $x = func_get_args();
  6.                 $args = array_merge(array(func_get_arg(1)),
  7.                     array_slice($x, 2));
  8.                 $arguments = array();
  9.                 foreach($args as $k => $arg) {
  10.                     $arguments[$k] = &$arg;
  11.                 }
  12.                 call_user_func_array(array($query, 'bind_param'), $arguments); //ругается
  13.             }
  14.             $query->execute();
  15.                         //etc...
  16.         }
  17.  


Пробую:
$db = $this->db->query('SLECT name, value FROM table WHERE id = ? AND name =?', 1 , 2);

Выдает мне:
Number of variables doesn't match number of parameters in prepared statement
Пришло 3 аргумента, а ушел массив параметров из 2х аргументов.
Как быть?
 
 Top
Мелкий Супермодератор
Отправлено: 22 Марта, 2016 - 19:05:59
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Зачем так сложно? Уже давно доступен:
PHP:
скопировать код в буфер обмена
  1. function query($query, ...$args) {
  2.     if ($query = $this->pdo->prepare($query)) {
  3.         $query->execute($args);
  4.     }
  5. }

И всё.

Правда, это PDO, а у вас mysqli с его странным апи... Ну значит будет какой-то обходной костыль. И вы забыли сформировать первый параметр для bind_param.
Но лучше переходите на pdo.


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB