Comment gérer les valeurs NULL dans les champs datetime MySQL
MySQL accepte les valeurs NULL dans les champs datetime, malgré l'idée fausse courante. Pour attribuer une valeur NULL à un champ datetime, laissez simplement la variable vide ou envoyez la valeur NULL explicitement.
Insérer des valeurs NULL à l'aide de MySQL
CREATE TABLE datetimetest (testcolumn DATETIME NULL DEFAULT NULL); INSERT INTO datetimetest (testcolumn) VALUES (NULL);
Insérer des valeurs NULL à l'aide d'instructions préparées PHP
Lorsque vous utilisez des instructions préparées, liez les variables comme d'habitude. Les variables PHP contenant des valeurs NULL seront stockées comme NULL dans MySQL.
$stmt = $conn->prepare("UPDATE users SET bill_date = ? WHERE user_id = ?"); if (isset($bill_date)) { $stmt->bind_param("si", $bill_date, $user_id); } else { $stmt->bind_param("si", NULL, $user_id); }
Remarque sur les variables vides PHP
Assurez-vous que les variables PHP contiennent NULL, pas une chaîne vide . Une chaîne vide entraînera une erreur :
Incorrect datetime value: '' for column 'bill_date' at row 1
Par conséquent, envoyez NULL explicitement ou laissez la variable vide pour éviter ce problème.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!