sql >> Database teknologi >  >> RDS >> Mysql

Sådan tjekker du i PHP, hvis der er angivet flere PDO-parametre end nødvendigt

Du har ret, den situation ser ikke ud til at give undtagelser eller udløse fejl. PDOStatement::execute() returnerer i det mindste false så du kan rulle din egen:

$dsn = "mysql:host=$dbhost;dbname=$dbname;charset=utf8mb4";
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES => false,
];
$pdo = new PDO($dsn, $dbuser, $dbpass, $options);

$sql = 'SELECT ? AS foo';
$stmt = $pdo->prepare($sql);

if (!$stmt->execute([1, 2])) {
    throw new InvalidArgumentException('Failed to execute statement');
}
while ($row = $stmt->fetch()) {
    var_dump($row);
}

Ikke ideelt, men...



  1. Hvad er standard root-adgangskoden til MySQL 5.7

  2. Hvad er hurtigere - INSTR eller LIKE?

  3. CURRENT_TIME Eksempler – MySQL

  4. Hvordan kan jeg få antallet af kunder pr. dag efter unikke og gentagne kunder for en bestemt dato?