Php PDO插入查询500服务器错误
我不熟悉使用PDO,提交表单时遇到http 500服务器错误 带有处理代码的php页面位于正确的文件夹中,因此我不知道为什么会抛出500错误 也没有进行url重写 这是我的密码:Php PDO插入查询500服务器错误,php,mysql,pdo,Php,Mysql,Pdo,我不熟悉使用PDO,提交表单时遇到http 500服务器错误 带有处理代码的php页面位于正确的文件夹中,因此我不知道为什么会抛出500错误 也没有进行url重写 这是我的密码: try { $dbh = new PDO("mysql:host=$hostname;dbname=crm",$username,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCE
try {
$dbh = new PDO("mysql:host=$hostname;dbname=crm",$username,$password);
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // <== add this line
$stmt = $db->prepare("INSERT INTO testdrives (forename, surname,phone,email,add1,add2,add3,city,county,postcode,car,date) VALUES (:forename, :surname,:phone,:email,:add1,:add2,:add3,:city,:county,:postcode,:car,:date)");
$stmt->bindParam(':forename', $_POST['forename']);
$stmt->bindParam(':surname', $_POST['surname']);
$stmt->bindParam(':phone', $_POST['phone']);
$stmt->bindParam(':email', $_POST['email']);
$stmt->bindParam(':add1', $_POST['add1']);
$stmt->bindParam(':add2', $_POST['add2']);
$stmt->bindParam(':add3', $_POST['add3']);
$stmt->bindParam(':city', $_POST['city']);
$stmt->bindParam(':county', $_POST['county']);
$stmt->bindParam(':postcode', $_POST['postcode']);
$stmt->bindParam(':car', $_POST['car']);
$stmt->bindParam(':date', $_POST['date']);
$stmt->execute();
if ($dbh->query($sql)) {
echo "<script type= 'text/javascript'>alert('New Record Inserted Successfully');</script>";
}
else{
echo "<script type= 'text/javascript'>alert('Data not successfully Inserted.');</script>";
}
$dbh = null;
}
catch(PDOException $e)
{
echo $e->getMessage();
}
试试看{
$dbh=newpdo(“mysql:host=$hostname;dbname=crm”,$username,$password);
$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//准备(“插入到测试驱动器(名字、姓氏、电话、电子邮件、地址1、地址2、地址3、城市、县、邮编、汽车、日期)值(:forename、:姓氏、:电话、:电子邮件、:add1、:add2、:add3、:城市、:县、:邮编、:汽车、:日期)”;
$stmt->bindParam(':forename',$\u POST['forename']);
$stmt->bindParam(':姓氏',$_POST['姓氏]);
$stmt->bindParam(':phone',$\u POST['phone']);
$stmt->bindParam(':email',$\u POST['email']);
$stmt->bindParam(':add1',$\u POST['add1']);
$stmt->bindParam(':add2',$\u POST['add2']);
$stmt->bindParam(':add3',$\u POST['add3']);
$stmt->bindParam(':city',$\u POST['city']);
$stmt->bindParam(':country',$_POST['country']);
$stmt->bindParam(':postcode',$\u POST['postcode']);
$stmt->bindParam(':car',$_POST['car']);
$stmt->bindParam(':date',$\u POST['date']);
$stmt->execute();
if($dbh->query($sql)){
回显“警报('成功插入新记录');”;
}
否则{
回显“警报('数据未成功插入');”;
}
$dbh=null;
}
捕获(PDO$e)
{
echo$e->getMessage();
}
编辑:
我错过了用于连接的不正确变量,即prepare中的$dbh
和$db
;我的错
原始答案 这一行:
if ($dbh->query($sql)) {...}
其失败有两个原因:
- 调用已经准备/执行的内容
- 使用不存在的变量,
$sql
$stmt->execute()代码>带有:
if($stmt->execute()){
// success
} else{
// error
}
使用PDO的错误处理(正如您现在所做的)和PHP的错误报告:
还要检查日志。编辑:
我错过了用于连接的错误变量,在准备中为$dbh
和$db
而使用;我的错
原始答案
这一行:
if ($dbh->query($sql)) {...}
其失败有两个原因:
- 调用已经准备/执行的内容
- 使用不存在的变量,
$sql
用相关的大括号去掉该语句,用simply替换它,并替换$stmt->execute()代码>带有:
if($stmt->execute()){
// success
} else{
// error
}
使用PDO的错误处理(正如您现在所做的)和PHP的错误报告:
同时检查日志。发现了问题
上面的代码显示
$stmt = $db->prepare
需要改成
$stmt = $dbh->prepare
谢谢你在其他问题上的帮助
快速问题如何插入到具有自动递增列的表中?发现问题
上面的代码显示
$stmt = $db->prepare
需要改成
$stmt = $dbh->prepare
谢谢你在其他问题上的帮助
快速提问如何插入到具有自动增量列的表中?if($dbh->query($sql))
这甚至不应该是您的代码的一部分。如果PHP出现500个错误,则会有一个带有实际错误的日志-如果您允许,PHP会告诉您出了什么问题。您的PHP日志中有什么错误?当您启用错误报告时,您看到了什么?500表示“发生了错误”,您需要查看该错误的实际情况。您还使用了保留的word@MasivuyeCokile“如果($dbh->query($sql)){}没有任何意义,就失去这一行”-if($dbh->query($sql))
这甚至不应该是代码的一部分。如果PHP出现500错误,有一个带有实际错误的日志-如果您允许,PHP会告诉您出了什么问题。您的PHP日志中有什么错误?当您启用错误报告时,您看到了什么?500表示“发生了错误”,您需要查看该错误的实际情况。您还使用了保留的word@MasivuyeCokile“如果($dbh->query($sql)){}没有任何意义,那么就丢失这一行”-看起来Op在标记时过敏了answers@MasivuyeCokile是 啊嗯,对此我们无能为力。“这是人生”——)仍然抛出相同的错误此错误显示在对非对象的成员函数prepare()的日志文件调用中,在/myfile.php的第13行,@ChrisYates啊,是的,很抱歉。我错过了错误的变量;我对我的答案进行了编辑。看起来Op对评分过敏answers@MasivuyeCokile是 啊嗯,对此我们无能为力。“这是人生”——)仍然抛出相同的错误此错误显示在对非对象的成员函数prepare()的日志文件调用中,在/myfile.php的第13行,@ChrisYates啊,是的,很抱歉。我错过了错误的变量;我修改了我的答案。