绑定值不工作

bindValue is not working

将 PDO 与 MariaDB 服务器一起使用。我无法理解为什么这段代码不起作用。每当我有 :value 的值时,它都会给我一个错误“无效的参数编号:参数未定义”

    $sql = "INSERT INTO table (USER, DOMAIN,FLG) VALUES (:username,:domain,:flag)";
    $stmt = $dbh->prepare($sql);
    $stmt->bindValue(':username', $username);
    $stmt->bindValue(':domain', $domain);
    $stmt->bindValue(':flag', $flag);       
    $stmt->execute();

但是下面的代码确实有效。

    $sql = "INSERT INTO table (USER, DOMAIN,FLG) VALUES (?,?,?)";
    $stmt = $dbh->prepare($sql);
    $stmt->bindValue(1, $username);
    $stmt->bindValue(2, $domain);
    $stmt->bindValue(3, $flag);       
    $stmt->execute();

下面是此代码部分的其余部分。

    if(isset($_POST['addEditor'])){
    $username = $_POST['formUsername'];
    $domain = $_POST['formDomain'];
    $flag = $_POST['formflg'];

    $sql = "INSERT INTO table (USER, DOMAIN,FLG) VALUES (:username,:domain,:flag)";
    $stmt = $dbh->prepare($sql);
    $stmt->bindValue(':username', $username);
    $stmt->bindValue(':domain', $domain);
    $stmt->bindValue(':flag', $flag);       
    $stmt->execute();


  try{                
    $stmt->execute();           
  }
  catch (Exception $e) {
    die ('ERROR: ' . $e->getMessage());
  }

那个对我有用的代码已经阅读了一些关于 PDO here

的内容
$dbh = new PDO("mysql:host=$dbhost;dbname=$dbname",$dbuser,$dbpass);
$username='a';
$domain ='b';
$flag ='c';
$sql = "INSERT INTO `table` (`USER`, `DOMAIN`, `FLG`) VALUES (:username,:domain,:flag)";
$stmt = $dbh->prepare($sql);
$stmt->execute(
  array(':username'=> $username,
    ':domain'=> $domain,
    ':flag'=> $flag)
  );

I am having trouble understanding why this code does not work.

难怪你理解错了

摆脱代码中的 all trycatch 运算符,运行 再次阅读 完整 错误消息,这将使您了解哪个 代码不起作用。

if($_POST)
{
$role ="student";



 try{

    $stmt = $db_con->prepare("INSERT INTO userinfo (role)
            VALUES(:qrole)");
        $stmt->bindParam(":qrole", $role);


        if($stmt->execute())
        {
            echo "Successfully Added";
        }
        else{
            echo "Query Problem";
        }   
    }
    catch(PDOException $e){
        echo $e->getMessage();
    }
}

试试这个,如果发生一些错误,它会 post 它使用 catch