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

Запрос INSERT INTO как построить запрос правильно?

27.12.2016, 23:26. Показов 9020. Ответов 35
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Народ помогите пожалуйста сделать запрос правильно.
Имеется таблица users в ней имеется данные для регистрации и данные для профиля.
При регистрации все го лишь нужно указать логин, email, пароль, еще раз пароль и все,
делаю такой запрос:
PHP
1
2
3
4
5
6
7
8
9
10
11
$sql = 'INSERT INTO `users`
(`user_id`, `login`, `email`, `pass`, `salt`, `active_hex`, `status`, `role`, `date_reg`,
    `name`, `surname`, `birthday`, `sex`, `country`, `city`, `avatar`)
VALUES (:user_id, :login, :email, :pass, :salt, :active_hex, 0, 3, NOW(),
    :name, :surname, :birthday, :sex, :country, :city, :avatar)';
                $stmt = $pdo->prepare($sql);
                $stmt->bindValue(':login', $_POST['login'], PDO::PARAM_STR);
                $stmt->bindValue(':email', $_POST['email'], PDO::PARAM_STR);
                $stmt->bindValue(':pass', $pass, PDO::PARAM_STR);
                $stmt->bindValue(':salt', $salt, PDO::PARAM_STR);
                $stmt->execute();
Выкидывает вот такую ошибку:
Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[21S01]: Insert value list does not match column list: 1136 Column count doesn't match value count at row 1' in

Еще делал запрос на регистрацию вот так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
                $sql = 'INSERT INTO `users`
                VALUES(
                "",
                :login,
                :email,
                :pass,
                :salt,
                :active_hex,
                0,
                3,
                NOW()
                )';
                $stmt = $pdo->prepare($sql);
                $stmt->bindValue(':login', $_POST['login'], PDO::PARAM_STR);
                $stmt->bindValue(':email', $_POST['email'], PDO::PARAM_STR);
                $stmt->bindValue(':pass', $pass, PDO::PARAM_STR);
                $stmt->bindValue(':salt', $salt, PDO::PARAM_STR);
                $stmt->execute();
Все ровно та же ошибка...
Нужно ли все поля указывать которые есть в таблице или нет?
Как правильно выглядеть данный запрос, что бы пропустить те поля которые заполняются позже, и то по желанию?
Может кто встречался с такой проблемой, или уже разобрался дайте совет.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.12.2016, 23:26
Ответы с готовыми решениями:

Как правильно построить запрос на выборку значений
Добрый день. Есть поле total_cost в нем хранится цена товара и поле new_cost в нем храниться цена с учетом скидки. Мне нужно вывести...

Как в sql запрос вставить еще один запрос правильно?
Есть длинный запрос, в котором можете даже не разбираться если не хотите, но выдает он следующее: Запрос: SELECT...

Как правильно выполнить запрос Insert.Into.Select.From.Where
Доброго утра всем, пытаюсь записать данные с лэйбла в последнюю строку БД, но выдает ошибку в данном методе. Dim Com = New...

35
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
28.12.2016, 22:27  [ТС]
Студворк — интернет-сервис помощи студентам
fanatikus, Ошибка первая Undefined index: user_id in
Ошибка вторая Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''аааа', 'аа', '2016-12-06', '1', 'а',' at line 2' in

Как вы мне рекомендовали создать одну таблицу, для данных о пользователях и данные для регистрации. Чем хранить в двух таблицах.
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
28.12.2016, 22:30
MySQL
1
... SET `field` = 'value', `field2` = 'value2', ....
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
28.12.2016, 22:33
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
Undefined index: user_id
судя по всему в массиве $_SESSION нет индекса user_id
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
28.12.2016, 22:40  [ТС]
fanatikus, вот что выдает vardamp
array(7) { ["name"]=> string(8) "аааа" ["surname"]=> string(4) "аа" ["birthday"]=> string(10) "2016-12-06" ["sex"]=> string(1) "1" ["country"]=> string(2) "а" ["city"]=> string(6) "ааа" ["add_details"]=> string(18) "Сохранить" }
Так а как же бороться с этим? Что мне подставить в сесию?
Чтобы данные заполнялись для данного пользователя.
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
28.12.2016, 23:13
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
вот что выдает vardamp
при чем var_dum($_POST)?
данных нет в сессии.
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
Так а как же бороться с этим?
добавить в сессию(при авторизации) идентификатор пользователя. и из сессии добавлять в запрос
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
29.12.2016, 15:13  [ТС]
fanatikus, Вроде как бы что то получилось, буду разбирать дальше.

Добавлено через 12 часов 47 минут
А как перед регистрацией, можно сделать, сперва он вводит данные о себе, а потом емаил, пароль.
А то я сделал сперва емаил, пароль, а потом данные о себе.
0
0 / 0 / 2
Регистрация: 29.12.2016
Сообщений: 22
29.12.2016, 17:38
PHP
1
2
3
4
5
6
7
8
9
10
$sql =
        "UPDATE `users` SET
        `name`=:name,
        `surname`=:surname,
        `birthday`='".$_POST['birthday']."',
        `sex`='".$_POST['sex']."',
        `country`=:country,
        `city`=:city,
        `avatar`=:avatar
        WHERE `user_id`='". $_SESSION['user_id'] ."'";
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
29.12.2016, 21:30  [ТС]
Sanych33, это запрос на обновления данных да я знаю)) Он у меня есть сейчас, спасибо.
У как мне перед отправкой письма, сделать заполнения формы данными, а потом сама регистрация?
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
29.12.2016, 22:31
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
сделать заполнения формы данными, а потом сама регистрация?
выводите все поля во время регистрации. допустим, логин и пароль обязательны, остальные по желанию. а потом в кабинете пользователь может(если захочет) добавить информацию о себе.
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
30.12.2016, 01:26  [ТС]
fanatikus, так у меня сделано, что типа после регистрации ему страницу показываю, то есть если я нажму на кабинет, то у меня там пишет так: Имя: пусто Фамилия: пусто и т.д.
А как мне заставить, работать скрипт так, что бы если он нажмет на кабинет, если данных нет, то выпадает форма для заполнения данных иначе выводим У Вас Еще не заполнена анкета,
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
30.12.2016, 13:00
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
если данных нет, то выпадает форма для заполнения данных иначе выводим У Вас Еще не заполнена анкета,
если пользователь зашел в кабинет, следовательно он уже зарегистрирован и как минимум в базе есть пароль и логин. правильно? что вы подразумеваете под, если данных нет? остальных данных? выводите форму с полями для всех данных. какие есть выводите в форме. остальные пустые. пользователь заполняет пустые, или редактирует заполненные, обновляете данные в базе.
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
30.12.2016, 16:40  [ТС]
fanatikus, да именно так, у пользователя уже и пароль и логин. Да подразумеваю если остальных данных нет. Вот тут я вас уже понял, буду пробовать сделать, спасибо.

Добавлено через 1 час 41 минуту
fanatikus, Вот дайте дельный совет, а как же пользователю выводить информацию?
Вот например, уже есть пароль и логин, их надо в кабинете выводить вместе с пустыми полями что не заполнены.
То есть в полях уже написан будет пароль и логин, а вот те данные которые не заполнил, они будут заполнять?
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
30.12.2016, 17:03
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
Вот например, уже есть пароль и логин, их надо в кабинете выводить вместе с пустыми полями что не заполнены.
ну да. может пользователь хочет изменить
Цитата Сообщение от _NE_KAKIX_IMEN_ Посмотреть сообщение
а вот те данные которые не заполнил, они будут заполнять?
да. заполнят, запишите в базу
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
30.12.2016, 18:00  [ТС]
fanatikus, Большое спасибо, буду разбираться!
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
02.01.2017, 19:56  [ТС]
С новым годом всех!
Народ у меня вопрос как можно ограничить число повтором входа, если он ввел 3 раза не правильно пароль ну или логин данные одним словом, то показываю ему капчу.
А то я сразу только кто входит на сайт показываю капчу.
Как можно сделать так?
0
0 / 4 / 1
Регистрация: 20.05.2015
Сообщений: 450
05.01.2017, 00:39  [ТС]
Всем привет, кто мне подскажет как можно реализовать функцию?
Можно ли все сделать в одном файле, вот у меня есть форма добавления и редактирования записи, у меня есть вывод информации.
Вопрос заключается в том как эти файлы объединить в один файл, что бы все было записано в одном файле
через case?
или через функции?
И можно показать маленький примерчик спасибо?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.01.2017, 00:39
Помогаю со студенческими работами здесь

Не работает запрос INSERT MySQLdb или как его правильно составить?
Есть код: import MySQLdb try: con = MySQLdb.connect(host="localhost", user="root", passwd="root", db="autopost") cur...

Как правильно построить БД и запрос
Здравствуйте.Нужна ваше помощь в создании бд. Задание следующее: Создать бд,содержащую данные: дата заказа,дата выполнения,и вид...

Как правильно построить запрос?
Собственно вся проблема продемонстрирована на прилагаемом рисунке. В некой таблице, существуют два поля, которые ссылаются на две...

Как правильно построить запрос
Добрый день) Имеется таблицы в БД содержащая строки: Дата заказа-DZ, дата выполнения-DW и вид работы-VR Помогите построить запросы:...

Как правильно построить запрос для графика?
Добрый день всем. Изначально в базе есть две таблицы - План и Факт. В них заносятся даты и суммы (показал на скрине ниже). То есть, если...


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

Или воспользуйтесь поиском по форуму:
36
Ответ Создать тему
Новые блоги и статьи
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