Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.61/46: Рейтинг темы: голосов - 46, средняя оценка - 4.61
 Аватар для Totoro
47 / 23 / 3
Регистрация: 28.05.2012
Сообщений: 150
Записей в блоге: 1

Не выполняется INSERT средствами PDO prepared statement

18.12.2012, 21:40. Показов 9548. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Собственно проблема не вставляются данные в бд когда передаю их через placeholder'ры когда передаю прямым запросом все нормально.

P.S ошибок невыдаёт.

содержание connect.conf.php:

PHP
1
2
3
4
5
6
<?php
    define('DB_DRIVER', 'mysql:host=localhost;dbname=pdo');
    define('DB_USER', 'root');
    define('DB_PASS', '');
    define('DB_OPTIONS', 'PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"');
?>
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php
    //Определение корневого пути и его оптимизация для кроссплатформенности
    define('ABSPATH', str_replace('\\', '/', dirname(__file__)) . '/');
    
    //Настройки для подключения к базе данных
    require_once ABSPATH .'/app/vars/connect.conf.php';
    
    //Подключение класса пользователи
    require_once ABSPATH .'/app/classes/users.class.php';
    
    //Подключение к базе данных
    try {
        $DBH = new PDO(DB_DRIVER, DB_USER, DB_PASS, array(DB_OPTIONS));
        mysql_set_charset('utf8');  
    } 
    catch (PDOException $e) {
        echo 'Хьюстон у нас проблемы с стыковкой к БД: <br />' . $e->getMessage();
    }
    
    try {
        $STH = $DBH->prepare("INSERT INTO product (title, producerFirstname, producerLastname, price) VALUES (?, ?, ?, ?)");
        $STH->bindParam(1, $title);
        $STH->bindParam(2, $producerFirstname);
        $STH->bindParam(3, $producerLastname);
        $STH->bindParam(4, $price);
    }
    catch (PDOException $e) {
        echo 'Хьюстон у нас проблемы с запросом к зонду <br />' . $e->getMessage();
    }
    
    //Вставка строки
    $title = 'Старик и море';
    $producerFirstname = 'Эрнест';
    $producerLastname = 'Хэмингуэль';
    $price = '3.95';
    
    $STH->execute();
    
    //Закрываем подключение
    $DBH = null;
?>
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.12.2012, 21:40
Ответы с готовыми решениями:

Как использовать, создавать Prepared statement?
Как использовать, создавать Prepared statement? например у меня есть код: $query = Database::query(&quot;SELECT `mail` FROM...

Number of variables doesn't match number of parameters in prepared statement
Собственно, код $query = mysqli_prepare($db, &quot;SELECT * FROM `users_db` WHERE `user_name`='?' || `e_mail`='?'&quot;); ...

Syntax error in INSERT INTO statement
Есть программа с базой данных Access. При попытке создать новую запись, выбивает ошибку: Syntax error in INSERT INTO statement. Где...

5
 Аватар для Dolphin
814 / 797 / 201
Регистрация: 21.09.2012
Сообщений: 2,656
18.12.2012, 22:00
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
try {
 
    
        //Вставка строки
        $title = 'Старик и море';
        $producerFirstname = 'Эрнест';
        $producerLastname = 'Хэмингуэль';
        $price = '3.95';
    
        $STH = $DBH->prepare("INSERT INTO product (title, producerFirstname, producerLastname, price) VALUES (?, ?, ?, ?)");
        $STH->bindParam(1, $title);
        $STH->bindParam(2, $producerFirstname);
        $STH->bindParam(3, $producerLastname);
        $STH->bindParam(4, $price);
 
        $STH->execute();
    }
    catch (PDOException $e) {
        echo 'Хьюстон у нас проблемы с запросом к зонду <br />' . $e->getMessage();
    }
    
    //Закрываем подключение
    $DBH = null;
0
 Аватар для Totoro
47 / 23 / 3
Регистрация: 28.05.2012
Сообщений: 150
Записей в блоге: 1
20.12.2012, 14:44  [ТС]
Dolphin, пробовал проблема осталась таже ошибок нет но и данные не заносит, а когда передаю без placeholder'ов все заносится нормально.

Добавлено через 57 минут
заменил:

PHP
1
2
$DBH = new PDO(DB_DRIVER, DB_USER, DB_PASS, array(DB_OPTIONS));
        mysql_set_charset('utf8');
на:

PHP
1
$DBH = new PDO(DB_DRIVER, DB_USER, DB_PASS);
т.е убрал задание кодировки. После этого стал производить вставку в БД но все данные кракозябликами.

файлы и таблицы в кодировке UTF-8.

Есть у кого мысли как задать кодировку что бы выборка и вставка проводились корректно.

P.S Интересный баг когда провожу вставку с указанием кодировки данные в бд не заносятся но если поле этого сразу провести выборку то выводятся данные из бд и те данные которые я вставляют но в бд при том их нет.

Добавлено через 36 минут
Решение нашел проблема была в том что я заносил
PHP
1
PDO::MYSQL_ATTR_INIT_COMMAND => "SET names utf8"
В константу т.е заменив

PHP
1
2
3
4
5
6
7
8
<?php
    //Данные для подклчения к БД
    define('DB_DRIVER','mysql:host=localhost;dbname=store');
    define('DB_USER','root');
    define('DB_PASS','');
    define('DB_DRIVER, 'PDO::MYSQL_ATTR_INIT_COMMAND => "SET names utf8");
  
?>
на:

PHP
1
2
3
4
5
6
7
8
<?php
    //Данные для подклчения к БД
    define('DB_DRIVER','mysql:host=localhost;dbname=store');
    define('DB_USER','root');
    define('DB_PASS','');
    $driver_options = array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET names utf8");
  
?>
все начало корректно работать и через placeholde'ры тоже.

По сему случаю решил провести тест:
PHP
1
2
3
4
<?php
     var_dump(DB_OPTIONS);
     echo '<br />'. DB_OPTIONS .'<br />';
?>
Результатом стало:
PHP
1
2
string(48) "PDO::MYSQL_ATTR_INIT_COMMAND => "SET names utf8"" 
PDO::MYSQL_ATTR_INIT_COMMAND => "SET names utf8"
P.S Как видно данные ничем не отличаются и в чем проблема не ясно,похоже есть какой то баг с обработкой данных из констант в запросах PDO.
0
 Аватар для Dolphin
814 / 797 / 201
Регистрация: 21.09.2012
Сообщений: 2,656
20.12.2012, 17:22
Вот этого я как то не заметил =)
Цитата Сообщение от Totoro Посмотреть сообщение
PHP
1
2
$DBH = new PDO(DB_DRIVER, DB_USER, DB_PASS, array(DB_OPTIONS)); 
mysql_set_charset('utf8');
Просто ты смешал два вида подключения PDO и mysql_connect. Из-за этого была ошибка
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
20.12.2012, 22:22
обычно хватает
PHP
1
$DBH->exec('SET NAMES utf8');
если не заносить в массив с настройками
0
 Аватар для Totoro
47 / 23 / 3
Регистрация: 28.05.2012
Сообщений: 150
Записей в блоге: 1
21.12.2012, 06:59  [ТС]
Цитата Сообщение от Dolphin Посмотреть сообщение
Вот этого я как то не заметил =)

Просто ты смешал два вида подключения PDO и mysql_connect. Из-за этого была ошибка
Самое интереное что ошибки не было после того как перенес из константы в переменную все заработало причем попробовал и этот костыль вписать с ним тоже все работает.

Добавлено через 3 минуты
Цитата Сообщение от KOPOJI Посмотреть сообщение
обычно хватает
PHP
1
$DBH->exec('SET NAMES utf8');
если не заносить в массив с настройками
в принципе да но хотелось что бы работало именно с файла настроек, и напрямую в подключении а то у меня память плохая могу и забыть гденить это вписать.

А так данная ошибка оказалась весьма интересной про такой баг с константами незнал
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.12.2012, 06:59
Помогаю со студенческими работами здесь

Syntax error in INSERT INTO statement
Есть код ADOQuery1-&gt;Close(); ADOQuery1-&gt;SQL-&gt;Clear(); ADOQuery1-&gt;SQL-&gt;Add(&quot;INSERT INTO Авторизація (Користувач) VALUES...

The INSERT statement conflicted with the FOREIGN KEY
В чем собственно у меня ошибка?(На 1 скрине) п. 4.11 Правил форума

Нюансы синтаксиса: как работают выражения вида statement = statement = statement?
Всем привет. Что значит такое выражение в c++? c = c2 = c/2; и как вообще работают такие выражения?

The INSERT statement conflicted with the FOREIGN KEY constraint
Добрый вечер. The INSERT statement conflicted with the FOREIGN KEY constraint &quot;FK_Product_Brand&quot;. The conflict occurred in database...

Insert и PDO
Прописываю Insert запрос к БД, с использованием PDO: $reg_data = array( 'user' =&gt; $user, 'password' =&gt; $password, 'email'...


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

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