Почему я получаю имена своих параметров вместо их значений в этом операторе вставки PDO? - PullRequest
0 голосов
/ 26 июня 2011

На самом деле это мой первый проект, в котором я использую PDO.

До сих пор это работало очень хорошо, но в данном конкретном случае в моей базе данных было следующее содержимое:

enter image description here

Немодифицированный код, который я использую, таков:

<?php
$dbh=new PDO('mysql:host=localhost;dbname=domain-me;port=3306','domain-me','****',array(PDO::MYSQL_ATTR_INIT_COMMAND=>"SET NAMES utf8"));
$sql="
INSERT INTO  payments_paypal (
tid ,
txn_id ,
item_number ,
item_name ,
mc_currency ,
mc_gross ,
payment_date ,
payment_status ,
custom ,
payer_email ,
raw_data
)
VALUES (
NULL ,  ':txn_id',  ':item_number',  ':item_name',  ':mc_currency',  ':mc_gross',  ':payment_date',  ':payment_status',  ':custom',  ':payer_email',  ':raw_data'
);
";
$sth=$dbh->prepare($sql);
$do=$sth->execute(array(':txn_id'=>@$_POST["txn_id"],':item_number'=>$_POST["item_number"],':item_name'=>$_POST["item_name"],':mc_currency'=>$_POST["mc_currency"],':mc_gross'=>$_POST["mc_gross"],':payment_date'=>$_POST["payment_date"],':payment_status'=>$_POST["payment_status"],':custom'=>$_POST["custom"],':payer_email'=>$_POST["payer_email"],':raw_data'=>$_POST["raw_data"],));
?>

редактирование:

Я сделал это, используя старую функцию mysql_function, и теперь она работает. Однако у меня есть этот запрос, который прекрасно работает:

$sql = "INSERT INTO users ( puid,refcode,extuid, login,login_proxy, pass, email) 
VALUES (:puid,:refcode,:extuid,:login,:login_proxy,:pass,:email);";
        $sth = $dbh->prepare($sql);

        $do = $sth->execute(
                array(
                ':puid' => $refuser,
                ':refcode' => crc32(uniqid('')),
                ':extuid' => md5(uniqid('')),
                ':login' => $_POST['login'],
                ':login_proxy' => $_POST['login'],
                ':pass' => sha1($_POST['pass']),
                ':email' => $_POST['email'] ,
                )
        );

1 Ответ

1 голос
/ 26 июня 2011

Я считаю, что при выполнении INSERT или UPDATE вам нужно указывать имена в массиве значений вставки без двоеточий.Попробуйте это:

<?php
$dbh=new PDO('mysql:host=localhost;dbname=domain-me;port=3306','domain-me','****',array(PDO::MYSQL_ATTR_INIT_COMMAND=>"SET NAMES utf8"));
$sql="
INSERT INTO  payments_paypal (
tid ,
txn_id ,
item_number ,
item_name ,
mc_currency ,
mc_gross ,
payment_date ,
payment_status ,
custom ,
payer_email ,
raw_data
)
VALUES (
NULL ,  ':txn_id',  ':item_number',  ':item_name',  ':mc_currency',  ':mc_gross',  ':payment_date',  ':payment_status',  ':custom',  ':payer_email',  ':raw_data'
);
";
$sth=$dbh->prepare($sql);
$do=$sth->execute(array('txn_id'=>@$_POST["txn_id"],'item_number'=>$_POST["item_number"],'item_name'=>$_POST["item_name"],'mc_currency'=>$_POST["mc_currency"],'mc_gross'=>$_POST["mc_gross"],'payment_date'=>$_POST["payment_date"],'payment_status'=>$_POST["payment_status"],'custom'=>$_POST["custom"],'payer_email'=>$_POST["payer_email"],'raw_data'=>$_POST["raw_data"],));
?>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...