IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Interdire la suppression d'une ligne dans une BDD


Sujet :

JavaScript

  1. #1
    Membre actif Avatar de griese
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    646
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 646
    Points : 281
    Points
    281
    Par défaut Interdire la suppression d'une ligne dans une BDD
    Bonjour à tous,
    J'ai site php avec une BDD, dans une page de mon site, il est possible de pouvoir supprimer des données dans la BDD. Par exemple j'ai une table SITE et une table AGENCE. chaque AGENCE dépend d'un site. Exemple :
    Table AGENCE :
    001|Agence1|1
    002|Agence2|1

    Table SITE :
    1|Site1
    2|Site2

    Donc je voudrai faire apparaître un message d'alert disant qu'on ne peut pas supprimer le site car des agences y sont relié. Et cela, lorsque l'on clique sur le bouton supprimer.
    Quelqu'un pouurrait'il m'aider ?
    Merci d'avance

  2. #2
    Membre régulier
    Inscrit en
    Mai 2004
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 103
    Points : 87
    Points
    87
    Par défaut
    tu connais l'ajax ?

    quand la personne clique sur supprimer, appelle une fonction javascript, qui grace a l'ajax va récupérer le resultat d'une requete sql (en l'occurence une requete qui va verifier que l'element que l'utilisateur veut supprimer ne se trouve pas dans la table agence) apres en fonction du resultat récupéré tu supprime ou non toujours grace a l'ajax qui te permettra d'executer une requete sql de suppression...

  3. #3
    Membre actif Avatar de griese
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    646
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 646
    Points : 281
    Points
    281
    Par défaut
    non je connais pas l'ajax c'est quoi, une équipe de foot ?
    Non, je rigole, j'ai déjà entendu parler, mais je sais pas du tout ce que c'est.
    tu peux m'expliquer s'il te plaît ? Merci

  4. #4
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    simplement:

    marque les items qui ne peuvent être supprimés, via un id, par exemple et en cliquant "supprimer" tu lances l'alerte pour les éléments marqués;

  5. #5
    Membre régulier
    Inscrit en
    Mai 2004
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 103
    Points : 87
    Points
    87
    Par défaut
    arg... j'avais fais une enorme reponse mais je l'ai pas posté et j'ai tout perdu: cry:

    faut que j'aille manger je la referais peut etre apres

  6. #6
    Membre régulier
    Inscrit en
    Mai 2004
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 103
    Points : 87
    Points
    87
    Par défaut
    dans ton HTML :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <...  onclick='Javascript:verifie('id_de_la_ligne_a_supprimer');' ...>
    dans ton fichier javascript (ton_fichier.js) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
     
    var http 	= getHTTPObject();
     
     
     
    	function getHTTPObject() {
    		var xmlhttp;
    		/*@cc_on
    		@if (@_jscript_version >= 5)
    			try {
    				xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
    			} catch (e) {
    				try {
    					xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    				} catch (E) {
    					xmlhttp = false;
    				}
    			}
    		@else
    		xmlhttp = false;
    		@end @*/
    		if (!xmlhttp && typeof XMLHttpRequest != 'undefined') {
    			try {
    				xmlhttp = new XMLHttpRequest();
    			} catch (e) {
    				xmlhttp = false;
    			}
    		}
    		return xmlhttp;
    	}
     
        function verifie(parametre){
     
            http.open("POST", "requete_verifie_avant_suppression.php", true);
    	http.onreadystatechange = function (){
     
    	    if (http.readyState == 4) {
     
    	        var resultat = http.responseText;
     
    		if (){
     
                    }
                    else{
     
                    }											
    	    }   
            http.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            http.send("id_ligne_a_supprimer="+parametre);
        }
    enfin ton fichier php ("requete_verifie_avant_suppression.php") :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     
    <?
    //j'ecris pas le code je te dis ce que tu dois faire
    connection a la bdd...
     
    //recuperation du parametre
    if(isset($_POST["id_ligne_a_supprimer"])){
     
    	$ligne_a_supprimer = $_POST["id_ligne_a_supprimer"];
    }
    //$ligne_a_supprimer contient la valeur de "parametre" (issu de la fonction verifie() )
     
    execution de la requete de verification (à savoir est ce que l'id de la ligne à supprimer se trouve dans la table AGENCE ?).
     
    si l'id se trouve dans la table AGENCE
        echo "suppression impossible";
    sinon
        execution de la requete de suppression
        echo "suppression effectuée";
    ?>
    enfin attention si tu veux passer plusieurs parametres a ta page php dans ta fonction javascript la syntaxe differe un peu :

    send("parametre1="+parametre1+"&parametre2="+parametre2+"&parametre3="+parametre3);

    pas de "&" pour le premier parametre, par contre "&" obligatoire pour les parametres suivants.

  7. #7
    Membre actif Avatar de griese
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    646
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 646
    Points : 281
    Points
    281
    Par défaut
    Merci pour ton aide,
    Par contre, le message d'erreur s'affiche dans une autre page php, en fait je voudrai que ce soit un message de type alert() qui s'affiche quand on clique sur le bouton supprimer.

  8. #8
    Membre régulier
    Inscrit en
    Mai 2004
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 103
    Points : 87
    Points
    87
    Par défaut
    normalement au lieu de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var resultat = http.responseText;
    tu fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    document.getElementById('id_de_ton_element').innerHTML = http.responseText;

    et l'element dont l'id est "id_de_ton_element" (ça peut etre un <table>, un <div>, un <tr>, un <td>...tout quoi) va recevoir ce que tu affiche dans requete_verifie_avant_suppression.php.

    par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <div id='id_de_ton_element'>
    </div>
    a ce moment la tous les echo que tu feras dans requete_verifie_avant_suppression.php viendront s'inclure au sein de ton div.

    par exemple si dans ta page php tu fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    echo "<table>";
    echo "<tr><td>test</td></tr>";
    echo "</table>";
    cela donnera dans ta page html :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <div id='id_de_ton_element'>
    <table>
    <tr><td>test</td></tr>
    </table>
    </div>


    pour ton cas j'ai présumé qu'au lieu d'affecter le contenu des echo dans le innerHTML de ton objet, on pouvait l'affecter a une variable javascript (je ne sais pas si sa marche en fait), si sa marche dans ta variable resultat tu auras "suppression impossible" ou "suppression effectuée", en aucun cas les echos de ta page php ne s'afficheront a l'ecran et tu pourras dans ta fonction javascript faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (resultat == "suppression impossible"){alert('supression impossible');}
    c'est ce que tu voulais non ?

  9. #9
    Membre actif Avatar de griese
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    646
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 646
    Points : 281
    Points
    281
    Par défaut
    [QUOTE=pit9.76]dans ton HTML :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <...  onclick='Javascript:verifie('id_de_la_ligne_a_supprimer');' ...>
    Le probleme c'est que je ne connais pas la valeur a verifier puisqu'elle choisie dans une liste déroulante dans cette même page. Donc je ne crois pas que ton code marcheras

  10. #10
    Membre actif Avatar de griese
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    646
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2006
    Messages : 646
    Points : 281
    Points
    281
    Par défaut
    En fait j'ai abandonné cette idée, je suis partit sur autre chose. Merci tout de même pour ton aide.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 15
    Dernier message: 21/10/2009, 13h31
  2. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  3. [E-00] Syntaxe pour insérer une ligne ou une colonne dans une feuille
    Par Benjycool dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/02/2009, 09h27
  4. [MySQL] inserer une ligne d'une table dans une autre table
    Par piero53 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 14/12/2008, 18h29
  5. Réponses: 3
    Dernier message: 29/01/2008, 12h08

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo