Php PDO插入查询500服务器错误

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

我不熟悉使用PDO,提交表单时遇到http 500服务器错误

带有处理代码的php页面位于正确的文件夹中,因此我不知道为什么会抛出500错误

也没有进行url重写

这是我的密码:

        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
用相关的大括号去掉该语句,用simply替换它,并替换
$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啊,是的,很抱歉。我错过了错误的变量;我修改了我的答案。