This didn't work for me because 42/0 doesn't produce a warning.
However this
<?php $conn->query('SELECT date("hello")'); ?>
produces
Warning (1292): Incorrect datetime value: 'hello'(PHP 8 >= 8.4.0)
Pdo\Mysql::getWarningCount — Returns the number of warnings from the last executed query
Returns the number of warnings from the last executed query.
Hinweis: For retrieving warning messages the following SQL command can be used:
SHOW WARNINGS [limit row_count].
Diese Funktion besitzt keine Parameter.
Returns an int representing the number of warnings generated by the last query.
Beispiel #1 Pdo\Mysql::getWarningCount() example
<?php
$conn = PDO::connect("mysql:host=localhost;dbname=test;charset=utf8mb4", 'user', 'password');
$conn->query('SELECT 42/0');
if ($conn->getWarningCount() > 0) {
    $result = $conn->query("SHOW WARNINGS");
    $row = $result->fetch();
    printf("%s (%d): %s\n", $row[0], $row[1], $row[2]);
}
?>Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
Warning (1365): Division by 0
This didn't work for me because 42/0 doesn't produce a warning.
However this
<?php $conn->query('SELECT date("hello")'); ?>
produces
Warning (1292): Incorrect datetime value: 'hello'