Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/26: Рейтинг темы: голосов - 26, средняя оценка - 4.77
5 / 5 / 0
Регистрация: 06.09.2011
Сообщений: 50

Запись данных из нескольких checkbox в БД

14.09.2011, 17:16. Показов 4986. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма в которой находится некое кол-во Checkbox :
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<input type="checkbox" class="sm" name="user_profile[10]" id="10"><label for="10">Автосервис</label> <br>
                <input type="checkbox" class="sm" name="user_profile[2]" id="2"><label for="2">Автоперевозки</label> <br>
                <input type="checkbox" class="sm" name="user_profile[17]" id="17"><label for="17">Воздушные перевозки</label> <br>
                <input type="checkbox" class="sm" name="user_profile[1]" id="1"><label for="1">Грузоотправители</label> <br>
                <input type="checkbox" class="sm" name="user_profile[5]" id="5"><label for="5">Диспетчер</label> <br>
                <input type="checkbox" class="sm" name="user_profile[15]" id="15"><label for="15">Железнодорожные перевозки</label> <br>
                <input type="checkbox" class="sm" name="user_profile[14]" id="14"><label for="14">Морские перевозки</label> <br>
                <input type="checkbox" class="sm" name="user_profile[16]" id="16"><label for="16">Мультимодальные перевозки</label> <br>
                <input type="checkbox" class="sm" name="user_profile[8]" id="8"><label for="8">Продажа запчастей</label> <br>
                <input type="checkbox" class="sm" name="user_profile[9]" id="9"><label for="9">Продажа автотехники</label> <br>
                <input type="checkbox" class="sm" name="user_profile[11]" id="11"><label for="11">Складские услуги</label> <br>
                <input type="checkbox" class="sm" name="user_profile[13]" id="13"><label for="13">Страхование</label> <br>
                <input type="checkbox" class="sm" name="user_profile[12]" id="12"><label for="12">Таможенные и брокерские</label> <br>
                <input type="checkbox" class="sm" name="user_profile[3]" id="3"><label for="3">Экспедиции</label> <br>
Есть обработчик этой формы в которой я пытаюсь вытащить данные то ест user_profile[] с отмеченными в checkbox и в дальнейшем записать данные из массива в БД.

Приведу часть кода
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<? 
$user_profile = array($_POST['user_profile']);
 
if(!empty($_POST['user_profile'])){ 
    $user_profile = implode(', ', $_POST['user_profile']); 
 
         // Проверка корректности введенного email - адреса.
            
            
               // Записываем в базу данных строку с данными нового пользователя.
               if($reg_q = mysql_query("Insert Into user Values (NULL,
               '".$face."','".$user_profile."', '".$gmt."','".$log."',md5('".$password."'), 0, '".$cnfrm_id."','".$date."')"))
               
               }
               else 
               { 
                  echo "Ошибочка в базе данных.. А-ля ".mysql_error();
               }
              
    
            }
            else
               {
               echo "Не удалось создать массив и записать его!!!";
               }
 ?>
:

Все как бы работает. Но записывает он в базу не значения. Например: 10,15,3, а всего лишь что checkbox выбран, то есть значение on,on,on в зависимости от того сколько checkbox отмечено.

Подскажите в чем моя ошибка в коде обработки.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.09.2011, 17:16
Ответы с готовыми решениями:

Запись в файл данных из checkbox
Добрый день!) Я не очень силен в пхп, и нужна помощь. Вопрос в следующем: Как записать в файл то что выберет пользователь из чекбокса? ...

Treeview данные от нескольких checkbox передать в запись в таблице
Здравствуйте! Есть БД, частью функционала которой является учет посещений сотрудниками населенных пунктов. С указанием административной...

Применение нескольких checkbox к datagrid для фильтрации данных
Есть 2 чекбокса, чекбокс1 = Имя1, чекбокс2 = Имя1. В датагрид данные идут и бд. Если я нажимаю на чекбокс1, то в датагрид фильтруется и...

9
 Аватар для dzjundzja88
289 / 234 / 32
Регистрация: 09.02.2011
Сообщений: 435
14.09.2011, 22:00
сериализируй свой массив, вместо переменной
PHP
1
$user_profile
в запросе напиши
PHP
1
serialize($_POST['user_profile'])
, а
PHP
1
$user_profile = implode(', ', $_POST['user_profile']);
вообще убери. Потом, когда нужно будет достать из базы айдишники выбраных чекбоксов, сделаешь unserialize() и опять у тебя будет массив.

и название чекбоксов пиши так
PHP
1
name="user_profile[]"
с пустыми скобками
1
5 / 5 / 0
Регистрация: 06.09.2011
Сообщений: 50
15.09.2011, 10:03  [ТС]
Цитата Сообщение от dzjundzja88 Посмотреть сообщение
сериализируй свой массив, вместо переменной
PHP
1
$user_profile
в запросе напиши
PHP
1
serialize($_POST['user_profile'])
, а
PHP
1
$user_profile = implode(', ', $_POST['user_profile']);
вообще убери. Потом, когда нужно будет достать из базы айдишники выбраных чекбоксов, сделаешь unserialize() и опять у тебя будет массив.

и название чекбоксов пиши так
PHP
1
name="user_profile[]"
с пустыми скобками
Может я что не правильно понял, но у меня получился вот такой код.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 
if(serialize($_POST['user_profile'])){ 
    
 
         // Проверка корректности введенного email - адреса.
            
            
               // Записываем в базу данных строку с данными нового пользователя.
               if($reg_q = mysql_query("Insert Into user Values (NULL,
                           '".$face."','".$user_profile."', '".$gmt."','".$log."',md5('".$password."'), 0, '".$cnfrm_id."','".$date."')"))
               
               }
               else 
               { 
                  echo "Ошибочка в базе данных.. А-ля ".mysql_error();
               }
                          
        
                        }
                        else
                           {
                           echo "Не удалось создать массив и записать его!!!";
                           }
И теперь вообще не чего не передается бд
0
 Аватар для dzjundzja88
289 / 234 / 32
Регистрация: 09.02.2011
Сообщений: 435
15.09.2011, 10:37
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php 
if(!empty($_POST['user_profile'])){ 
 
         // Проверка корректности введенного email - адреса.
            
            
               // Записываем в базу данных строку с данными нового пользователя.
               if($reg_q = mysql_query("Insert Into user Values (NULL,
                           '".$face."','".serialize($_POST['user_profile'])."', '".$gmt."','".$log."',md5('".$password."'), 0, '".$cnfrm_id."','".$date."')"))
               
               }
               else 
               { 
                  echo "Ошибочка в базе данных.. А-ля ".mysql_error();
               }
                          
        
                        }
                        else
                           {
                           echo "Не удалось создать массив и записать его!!!";
                           }
 ?>
1
5 / 5 / 0
Регистрация: 06.09.2011
Сообщений: 50
15.09.2011, 10:38  [ТС]
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
$user_profile = serialize($_POST['user_profile']);
 
 
if(!empty($_POST['user_profile'])){ 
     
 
         // Проверка корректности введенного email - адреса.
            
            
               // Записываем в базу данных строку с данными нового пользователя.
               if($reg_q = mysql_query("Insert Into user Values (NULL,
                           '".$face."','".$user_profile."', '".$gmt."','".$log."',md5('".$password."'), 0, '".$cnfrm_id."','".$date."')"))
               
               }
               else 
               { 
                  echo "Ошибочка в базе данных.. А-ля ".mysql_error();
               }
                          
        
                        }
                        else
                           {
                           echo "Не удалось создать массив и записать его!!!";
                           }
добился вывода вот такого вида.

a:8:{i:10;s:2:"on";i:2;s:2:"on";i:17;s:2 :"on";i:14...

Я так понял это правильно.
0
 Аватар для dzjundzja88
289 / 234 / 32
Регистрация: 09.02.2011
Сообщений: 435
15.09.2011, 10:43
не правильно напиши в именах чекбоксов
PHP
1
name="user_profile[]"
индексы в массиве не нужны. Он сам поставит по порядку, а то у тебя айдишники получаются индексами массива, а все значения равны "on"
0
5 / 5 / 0
Регистрация: 06.09.2011
Сообщений: 50
15.09.2011, 10:55  [ТС]
Цитата Сообщение от dzjundzja88 Посмотреть сообщение
не правильно напиши в именах чекбоксов
PHP
1
name="user_profile[]"
индексы в массиве не нужны. Он сам поставит по порядку, а то у тебя айдишники получаются индексами массива, а все значения равны "on"
А если убрать значения из name из скобок, он все равно выдает.

a:8:{i:0;s:2:"on";i:1;s:2:"on";i:2;s:2:" on";i:3;s:...
0
 Аватар для dzjundzja88
289 / 234 / 32
Регистрация: 09.02.2011
Сообщений: 435
15.09.2011, 11:02
Все равно не правильно. Вместо "on" должен быть айди. Вечером буду дома, поможу.
0
5 / 5 / 0
Регистрация: 06.09.2011
Сообщений: 50
15.09.2011, 11:58  [ТС]
может поставить value="10" и.т.д.
0
 Аватар для dzjundzja88
289 / 234 / 32
Регистрация: 09.02.2011
Сообщений: 435
15.09.2011, 21:23
Размести этот код в одном файле и посмотри как он работает
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<form action="" method="post" name="f">
<fieldset>
<legend>Твои чекбоксы</legend>
<?php
    echo "<input  type='checkbox' name='p[]'  value='1'><label >Автоперевозки1</label> <br>  ";
    echo "<input  type='checkbox' name='p[]'  value='2'><label >Автоперевозки2</label> <br>  ";
?>
    <input type="submit" value="Отправить" name="published"><br /><br />
</fieldset>
</form>
<?php
if($_POST)
{
  $user_profile = implode(', ', $_POST['p']);
    echo '<br /><br />Индексы чекбоксов '.$user_profile;
}
?>
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.09.2011, 21:23
Помогаю со студенческими работами здесь

Запись данных с CheckBox в БД
Здравствуйте) Делаю резюме для пользователя и столкнулся с таким вопросом: как записать данные с одного или нескольких checkBox'ов в БД?...

Запись данных согласно отмеченным checkbox в переменную
Всем Привет. Написал на php код, в котором отмечаешь чекбоксы, нажимаешь на кнопку и эти данные записываются в переменную. Теперь мне надо...

Запись данных из нескольких Edit в один столбец
Всем доброго вечера. Дело в том, что мне нужно из нескольких эдитов, добавить данные в БД Access в один столбец. Я прописывала код...

Запись в лог данных, собираемых с нескольких потоков
есть нужда вести лог многопоточной программы. есть концепция: потоки заносят инфу в некую переменную, форма тянет ее по таймеру. есть...

Перебор нескольких массивов и запись данных в базу
Здравствуйте! У меня есть форма с динамическим добавлением полей в неё. Также имеется функция для её обработки. &lt;form...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru