14.5.3 Syntaxe de SHOW
14.5 Référence de langage d'administration de la base de données
14 Syntaxe des commandes SQL
Manuel de Référence MySQL 4.1 : Version Française
. Syntaxe de SET . Commande SHOW CHARACTER SET . SHOW COLLATION . SHOW COLUMNS Syntax . Syntaxe de SHOW CREATE DATABASE . Syntaxe de SHOW CREATE TABLE . Obtenir des informations sur les bases, tables, colonnes et index . Syntaxe SHOW ENGINES . Syntaxe de SHOW ERRORS . SHOW GRANTS . Syntaxe de SHOW INDEX . Syntaxe de SHOW INNODB STATUS . Syntaxe de SHOW LOGS . SHOW PRIVILEGES . Syntaxe de SHOW PROCESSLIST . Syntaxe de SHOW STATUS . SHOW TABLE STATUS . Syntaxe SHOW TABLES . Syntaxe de SHOW VARIABLES ->SHOW WARNINGS | ERRORS
|
14.5.3.20 SHOW WARNINGS | ERRORS
SHOW WARNINGS [LIMIT #] SHOW ERRORS [LIMIT #]
|
Cette commande est implementée en MySQL 4.1.0.
Cette commande affiche les erreurs, alertes et notes qui ont été générées
par la dernière commande. Les erreurs et alertes sont remises à zéro pour
chaque nouvelle commande qui utilisent une table.
Le serveur MySQL retourne le nombre total d'alertes et d'erreurs que vous
avez obtenu lors de la dernière commande. Ils sont disponibles avec la
fonction
mysql_warning_count()
.
Jusqu'à
max_error_count
messages peuvent être stockés
(variable globale et spécique aux threads).
Vous povez lire le nombre d'erreurs dans
@error_count
et
le nombre d'alertes dans
@warning_count
.
SHOW WARNINGS
affiche aussi toutes les erreurs, alertes et notes
de la dernière commande, alors que
SHOW ERRORS
ne montre que
les erreurs.
mysql> DROP TABLE IF EXISTS no_such_table; mysql> SHOW WARNINGS; +-------+------+-------------------------------+ | Level | Code | Message | +-------+------+-------------------------------+ | Note | 1051 | Unknown table 'no_such_table' | +-------+------+-------------------------------+
|
Notez que depuis MySQL 4.1.0, nous avons ajouté un nouveau système d'alertes,
et peu de comandes MySQL génère des alertes. 4.1.1 supporte toutes sortes
d'alertes pour
LOAD DATA INFILE
et les commandes DML telles que
INSERT
,
UPDATE
et
ALTER
.
Par exemple, voici une situation simple qui produit des alertes de conversions
pour une commande d'insertion :
mysql> create table t1(a tinyint NOT NULL, b char(4)); Query OK, 0 rows affected (0.00 sec) mysql> insert into t1 values(10,'mysql'),(NULL,'test'),(300,'open source'); Query OK, 3 rows affected, 4 warnings (0.15 sec) Records: 3 Duplicates: 0 Warnings: 4 mysql> show warnings; +---------+------+---------------------------------------------------------------+ | Level | Code | Message | +---------+------+---------------------------------------------------------------+ | Warning | 1263 | Data truncated for column 'b' at row 1 | | Warning | 1261 | Data truncated, NULL supplied to NOT NULL column 'a' at row 2 | | Warning | 1262 | Data truncated, out of range for column 'a' at row 3 | | Warning | 1263 | Data truncated for column 'b' at row 3 | +---------+------+---------------------------------------------------------------+ 4 rows in set (0.00 sec)
|
Le nombre maximal d'alertes peut être spécifié en utilisant la variable
de serveur
'max_error_count'
,
SET max_error_count=[count]
; Par
défaut, c'est 64. Pour désactiver les alertes, donnez simplement la valeur
de 0 à la variable. Si
max_error_count
vaut 0, alors le nombre d'alertes
représente toujours le nombre d'alertes qui ont eu lieu, mais aucun message
d'erreur n'est accessible.Par exemple, observez la commande
ALTER
suivante, pour l'exemple ci-dessus,
qui retourne uniquement une alerte, même si le nombre total d'arlertes
est de 3 lorsque
'max_error_count'
=1.
mysql> show variables like 'max_error_count'; +-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | max_error_count | 64 | +-----------------+-------+ 1 row in set (0.00 sec) mysql> set max_error_count=1; Query OK, 0 rows affected (0.00 sec) mysql> alter table t1 modify b char; Query OK, 3 rows affected, 3 warnings (0.00 sec) Records: 3 Duplicates: 0 Warnings: 3 mysql> show warnings; +---------+------+----------------------------------------+ | Level | Code | Message | +---------+------+----------------------------------------+ | Warning | 1263 | Data truncated for column 'b' at row 1 | +---------+------+----------------------------------------+ 1 row in set (0.00 sec) mysql>
|
|