Modular Business

Tel: 00212 648154672 | Mail: Hamza.Abdeljabbar@gmail.com



Trackin

php016

Après avoir vu l'affichage des données provenant d'une base de données, l'insertion et la modification de ces mêmes données, voyons maintenant la dernière opération fondamentale concernant ces base de données : la suppression de tuples.

Reprenons alors nos deux tables liste_proprietaire et liste_disque que nous avons utilise pendant tous les tutoriaux concernant les bases de données.

Je vous rappelle que l'on avait alors :

La table liste_proprietaire :

N. du propriétaire Propriétaire N. tél
1 LA GLOBULE 06-48-85-20-54
2 Jeremy 06-85-98-78-12
3 Benoît 06-55-99-10-00
4 Tibo 06-98-42-01-36


La table liste_disque :


N. du propriétaire Auteur Titre
1 Cassius Au rêve
1 Daft Punk Discovery
2 Cassius Au rêve
2 Télépopmusik Genetic world
3 Clamaran Release yourself
2 Bob Sinclar Paradise
4 The supermen lovers The player

Voyons alors, en SQL, comment supprimer un tuple de la table liste_proprietaire.

Supposons que l'on désire supprimer Tibo de notre base de données. On écrira alors :

DELETE from liste_proprietaire WHERE nom="Tibo";


En effet, on efface un tuple (ou plusieurs, tout dépend de la clause WHERE) de quelle table ?
De la table liste_proprietaire.
Quel(s) tuple(s) efface-t-on ?
On efface tous les tuples de la table liste_proprietaire ou l'attribut nom prend la valeur Tibo (dans notre cas, un seul tuple porte la valeur Tibo pour l'attribut nom).

Notez bien que la clause WHERE peut très bien contenir plusieurs conditions, elles seront alors séparés par des opérateurs booléens (AND correspondant à un ET logique ou OR correspondant à un OU logique).

Cependant, je vous rappelle que des requêtes SQL peuvent être beaucoup plus complexes, et dans ce cas, je vous renvoie à la documentation MySQL, ce qui à notre niveau (débutant) n'est pas vraiment intéressant (cela ne sert à rien de vous embrouiller les idées dès le départ).

Attention !!!

Lorsque l'on effectue une suppression de tuples, il faut toujours faire attention à effacer non seulement les tuples de la table dont on veut supprimer le(s) élément(s) mais éventuellement les autres tuples d'une autre table (si les deux tables sont jointes par le biais d'un attribut).

En effet, dans notre exemple, nous venons de supprimer de la table liste_proprietaire le tuple dont l'attribut nom valait Tibo. Cependant, on remarque que la table liste_disque comporte des éléments qui étaient liés à Tibo. Or, vu que ces elements ne nous servent plus à rien maintenant (car on a supprimer Tibo de la liste), il faut également penser à les supprimer (afin d'avoir une base de données homogène).


Voyons maintenant comment effectuer ces suppressions par le biais d'une page WEB écrite en PHP.
Prenons par exemple le cas d'une page PHP permettant la suppression de Tibo de la base de données ainsi que de toutes les informations le concernant (c'est-à-dire les disques lui appartenant).

On aura alors :

exemple1
  1. <?php
  2. // on se connecte à notre base  
  3. $base = mysql_connect ('serveur', 'login', 'pass');  
  4. mysql_select_db ('ma_base', $base) ;  
  5. ?>
  6. <html>
  7. <head>
  8. <title>Suppression de Tibo de la base</title>
  9. </head>
  10. <body>
  11. <?php
  12. // lancement de la requête pour effacer Tibo  
  13. $sql ='DELETE from liste_proprietaire WHERE nom="Tibo"';  
  14.  
  15. // on exécute la requête (mysql_query) et on affiche un message au cas où la requête ne se passait pas bien (or die)  
  16. mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error());  
  17.  
  18. // lancement de la requête pour effacer les disques de Tibo (je vous rappelle que Tibo à le numéro 4)  
  19. $sql ='DELETE from liste_disque WHERE numero="4"';  
  20.  
  21. // on exécute la requête (mysql_query) et on affiche un message au cas où la requête ne se passait pas bien (or die)  
  22. mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error());  
  23.  
  24. // on ferme la connexion à la base  
  25. mysql_close();  
  26. ?>
  27. Tibo et tous ces disques ont étés supprimés de la base de données.
  28. </body>
  29. </html> 



Que faire en plus ?

Comme dans les tutoriaux précédents, afin de rendre vos pages beaucoup plus dynamiques, il serait intéressant de faire une page WEB contenant un formulaire possédant un menu déroulant permettant de choisir le nom du membre à effacer.
On suppose alors que ce menu déroulant à le champ NAME qui prend la valeur proprio, et que le formulaire a son champ ACTION qui prend la valeur traitement.php.
Ceci implique que dans la page traitement.php, on aura une variable $proprio qui contient le nom du propriétaire à supprimer.

On aura alors le code suivant (pour la page traitement.php placée dans le même répertoire que la page WEB contenant le formulaire) :

exemple2
  1. <?php
  2. // on se connecte à notre base  
  3. $base = mysql_connect ('serveur', 'login', 'pass');  
  4. mysql_select_db ('ma_base', $base) ;  
  5. ?>
  6. <html>
  7. <head>
  8. <title>Suppression d'un membre de la base</title>
  9. </head>
  10. <body>
  11. <?php
  12. // on teste si la variable du formulaire est bien déclarée  
  13. if (isset($_POST['proprio'])) { 
  14.  
  15.       // on recherche le numero du membre à supprimer 
  16.       $sql = 'SELECT numero FROM liste_proprietaire WHERE nom = "'.$_POST[proprio].'"'; 
  17.  
  18.       // on lance la requête (mysql_query) et on impose un message d'erreur si la requête ne se passe pas bien (or die) 
  19.       $req = mysql_query($sql) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error()); 
  20.  
  21.       // on recupere le resultat sous forme d'un tableau 
  22.       $data = mysql_fetch_array($req); 
  23.  
  24.       // on recupere la valeur qui nous intersse 
  25.       $numero_du_proprio = $data['numero']; 
  26.  
  27.       // on libère l'espace mémoire alloué pour cette interrogation de la base 
  28.       mysql_free_result ($req); 
  29.  
  30.       // lancement de la requête pour effacer notre membre 
  31.       $sql ='DELETE from liste_proprietaire WHERE nom="'.$_POST['proprio'].'"'; 
  32.  
  33.       // on exécute la requête (mysql_query) et on affiche un message au cas où la requête ne se passait pas bien (or die) 
  34.       mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error()); 
  35.  
  36.       // lancement de la requête pour effacer les disques de notre membre 
  37.       $sql ='DELETE from liste_disque WHERE numero="'.$numero_proprio.'"'; 
  38.  
  39.       // on exécute la requête (mysql_query) et on affiche un message au cas où la requête ne se passait pas bien (or die) 
  40.       mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error()); 
  41.  
  42.       // on ferme la connexion à la base 
  43.       mysql_close(); 
  44.  
  45.       // un petit message afin de voir ce qui s'est passé 
  46.       echo 'Nous venons de supprimer '.$_POST['proprio'].' de la base ainsi que tous ces disques';  
  47. }  
  48. else { 
  49.       echo 'La variable de notre formulaire n'est pas initialisée.';  
  50. }  
  51. ?>
  52. </body>
  53. </html> 


Et voila, maintenant, vous devez maîtriser tout ce qui concerne les bases de données et les pages dynamiques en PHP.
 

Meilleurs partenaires Trackin VIP


Vous êtes un membre ?

Veuillez s’inscrire si vous ne disposez pas d’un compte sur le site pour profiter des meilleurs services du webmastering au but de perfectionner votre site web, avoir quelques aides à propos de votre site ...

Ce site web a été créé gratuitement avec Ma-page.fr. Tu veux aussi ton propre site web ?
S'inscrire gratuitement