sql >> Databáze >  >> RDS >> Mysql

pdo vykonat give's error

Z příručky PDO::prepare ;

To (bohužel) znamená, že budete muset duplikovat své vazby se sekundárními názvy, abyste stejnou hodnotu použili v dotazu dvakrát. Ne hezké, něco jako;

$sth = $db->prepare(
  'INSERT INTO track (`rsname`, `overallranknow`, `overalllevelnow`, `overallxpnow` )' .
    'VALUES (:name, :Overalln, :Overall1, :Overall2) '. 
    'ON DUPLICATE KEY UPDATE ' .
      "rsname = :name_2"  .
      "overallranknow = :Overalln_2" .
      "overalllevelnow = :Overall1_2" .
      "overallxpnow = :Overall2_2" 
);
$sth->bindValue(':name', $name, PDO::PARAM_STR);
$sth->bindValue(':name_2', $name, PDO::PARAM_STR);
$sth->bindValue(':Overalln', $Overalln, PDO::PARAM_INT);
$sth->bindValue(':Overalln_2', $Overalln, PDO::PARAM_INT);
$sth->bindValue(':Overall1', $Overall[1], PDO::PARAM_INT);
$sth->bindValue(':Overall1_2', $Overall[1], PDO::PARAM_INT);
$sth->bindValue(':Overall2', $Overall[2], PDO::PARAM_INT);
$sth->bindValue(':Overall2_2', $Overall[2], PDO::PARAM_INT);
$sth->execute();

EDIT:Protože MySQL umožňuje VALUES klíčové slovo v ON DUPLICATE KEY abyste nemuseli opakovat parametry, měli byste pro tento případ lépe použít odpověď @YourCommonSense.



  1. 4 způsoby, jak získat informace o struktuře tabulky v SQLite

  2. LOAD_FILE vrátí hodnotu NULL

  3. Prohledávání MySQL pomocí PHP

  4. Seskupit podle klauzulí – elein's GeneralBits