Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak sprawdzić w PHP, czy podano więcej parametrów PDO niż potrzeba?

Masz rację, ta sytuacja nie wydaje się powodować wyjątków ani błędów. PDOStatement::execute() przynajmniej zwraca false więc możesz rzucić własne:

$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);
}

Nie idealne, ale...



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wyprowadzaj wiersze z wartością null tylko wtedy, gdy nie ma tego samego wiersza z wartością inną niż null

  2. MySQL - Wybierz dane za pomocą JOIN, ale z klauzulami WHERE dotyczącymi złożonych i odrębnych obwodów

  3. wstawiaj zapytanie z ajaxem bez przeładowywania całej strony

  4. Jak przenieść moją bazę danych MySQL na inny komputer?

  5. Przechowywanie pozycji koszyka w plikach cookie i bazie danych