Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 1
Регистрация: 30.09.2014
Сообщений: 126

Функция для PDO execute

16.07.2018, 08:57. Показов 1530. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Есть функция, которая автоматически собирает значения в инпутах и формирует часть запроса в бд, выглядит она так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function pdoSet($allowed, &$values, $source = array()) {
  $set = '';
  $values = array();
  if (!$source) $source = &$_POST;
  foreach ($allowed as $field) {
    if (isset($source[$field])) {
      $set.="`".str_replace("`","``",$field)."`". "=:$field, ";
      $values[$field] = $source[$field];
        
    }
  }
  return substr($set, 0, -2); 
  
}
Все ок, но если передавать массив, то в базу вставляется только - Array. Остальной код выглядит так:
PHP
1
2
3
$sql = "INSERT INTO campaigns SET ".pdoSet($allowed,$values);
$stm = $pdo->prepare($sql);
$stm->execute($values);
HTML5
1
2
3
4
5
6
7
8
<form method="POST">
    <input type="text" name="name" />
    <input type="checkbox" name="category[]" value="one" />
    <input type="checkbox" name="category[]" value="two" />
    <input type="checkbox" name="category[]" value="three" />
    <input type="text" name="format" />
    <input type="submit" name="submit" />
</form>
Функцию не я писал и особо в ней не понимаю что к чему. Подскажите, что нужно сделать, чтобы массив передавался корректно?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.07.2018, 08:57
Ответы с готовыми решениями:

$pdo->execute Выдает ошибку
Здравствуйте! Весь день не могу понять почему не работает код. обьект создается корректно, записывать в базу получается, но вот при чтении...

PDO - not execute
И так делаю подключение к ДБ через PDO.PDO возвращает PDOobject()..все OK.. Теперь делаю обычный запрос &quot; SELECT username FROM...

Mssql PDO execute procedure return output data
Приветствую гуру! есть хранимая процедура на сервере DECLARE @Code varchar(8) EXEC @return_value = . @dID = id, @Code = @Code...

5
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
16.07.2018, 10:06
Цитата Сообщение от mortido Посмотреть сообщение
если передавать массив, то в базу вставляется только - Array
Какой массив? Вы хотите записать сразу несколько строк в таблицу?
0
0 / 0 / 1
Регистрация: 30.09.2014
Сообщений: 126
16.07.2018, 10:21  [ТС]
Para bellum, нет, мне нужно занести одну строку в таблицу, в которой должны быть все значения массива. Массив - category[]. В последней части кода он есть
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
16.07.2018, 12:01
Лучший ответ Сообщение было отмечено mortido как решение

Решение

Попробуйте так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function pdoSet($allowed, &$values, $source = array()) {
  $set = '';
  $values = array();
  if (!$source) $source = &$_POST;
  foreach ($allowed as $field) {
    if (isset($source[$field])) {
      $set.="`".str_replace("`","``",$field)."`". "=:$field, ";
 
      $values[$field] = is_array($source[$field]) ? json_encode($source[$field]) : $source[$field];
        
    }
  }
  return substr($set, 0, -2); 
  
}
Теперь, если значение будет массивом, оно будет преобразован в JSON.

Но учтите, что записывать массивы в одно поле неправильно. Нужно подумать о нормализации.
1
0 / 0 / 1
Регистрация: 30.09.2014
Сообщений: 126
16.07.2018, 13:51  [ТС]
Para bellum, почему?
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
16.07.2018, 14:34
Чтобы не печатать самому, цитирую:
Общее назначение процесса нормализации заключается в следующем:

- исключение некоторых типов избыточности;
- устранение некоторых аномалий обновления;
- разработка проекта базы данных, который является достаточно «качественным» представлением реального мира,
- интуитивно понятен и может служить хорошей основой для последующего расширения;
- упрощение процедуры применения необходимых ограничений целостности.
Более подробно тут: https://ru.wikipedia.org/wiki/... 0%BC%D0%B0

Добавлено через 7 минут
Если простыми словами:
- Без кривых решений не получится искать записи, относящиеся к определённой категории. При использовании JOIN -- вообще туман.
- Можно будет записать категорию, даже если её нет (т.к. при подобном подходе нельзя внешние ключи использовать).
- Если категория удаляется, без кривых решений не удастся отследить относящихся к ней потомков и запретить удаление (ON DELETE RESTRICT) или удалить все относящиеся (ON DELETE CASCADE).

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

Как быть с подготовленными запросами в PDO? execute() не возвращает количество затронутых строк
Метод exec() возвращает количество затронутых строк, но его нельзя использовать в подготовленных запросах. Для этого существует метод...

Функция mysql_result в PDO
Здравствуйте. Помогите, пожалуйста. Как можно заменить функцию mysql_result() в PDO? Имеется следующий код: $query =...

Функция с возвратом результата EXECUTE IMMEDIATE
Добрый день! Суть: нужно, чтобы функция вернула то, что возвращает EXECUTE IMMEDIATE, а именно: либо таблица с одной колонкой, либо...

Error H2365: "Override method poster.execute shold match case of ancesor TThread.execute"
Собственно сабж... на ембаркадеро 2010. кто может подсказать как исправить? ведет на строку обьявления главной процедуры потока ...

OpenDialog1.Execute/SaveDialog1.Execute
Добрый день. Помогите, пожалуйста: unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
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 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru