Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 14/03/2007, 12h55   #1
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
Par défaut Test de présence d'un champ dans une table

Bonjour,

J'ai besoin de supprimer un champ dans une table si ce champ existe

J'aurai voulu faire quelque chose comme ceci :

Code :
ALTER TABLE maj_banque_compte DROP  IF EXISTS marquage
Mais bien sûr cela ne fonctionne.

Quelle syntaxe utiliser ?

autre bien sûr que de rechercher avec un
Code :
SHOW COLUMNS FROM Nom_table [FROM Nom_bdd] [LIKE wild]
Et si j'ai 1 alors c'est qu'il existe


Merci d'avance
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/03/2007, 17h46   #2
Membre extrêmement actif
 
Avatar de lodan
 
Inscription : juin 2006
Messages : 1 804
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 1 804
Points : 587
Points : 587
J'ai fait comme ceci :

Code :
1
2
3
4
5
6
7
8
$sql = "SHOW COLUMNS FROM $table LIKE 'marquage'";
$result = mysql_query($sql)OR die("Recherche marquage".mysql_error());
$numrow = mysql_num_rows($result);
IF($numrow!='0')
{
	$sql = "ALTER TABLE $table DROP marquage";
	mysql_query($sql)OR die("Demarquage".mysql_error());
}
Merci d'avoir regardé, mais s'il y a plus simple je suis preneur.
lodan est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h26.


 
 
 
 
Partenaires

Hébergement Web