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

PHP & Base de données Discussion :

test si existe dans la table [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut test si existe dans la table
    Bonjour.

    Si je place cette commande sans ajouter WHERE `shorturl` NOT IN ('test'), ça va fonctionner. "test" va être ajouté peut importe qu'il existe ou non.

    Je veux ajouter "test" que s'il n'existe pas dans la table. Faire ça en mysql.

    Comment?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO `site`.`table` (`id`, `shorturl`, `longurl`) VALUES (NULL, 'test', 'test.com') WHERE `shorturl` NOT IN ('test')

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920

  3. #3
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    Y'a d'autres choses qui faut ajouter à ce que je comprends. Mais, je veux simplement ne pas insérer si la valeur existe.

    INSERT IGNORE ... ne fonctionne pas.
    INSERT IGNORE INTO non plus.

    Citation Envoyé par stealth35 Voir le message

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    il faut bien mettre tes indexes, visiblement shorturl doit avoir un index UNIQUE, tu l'as bien mis ?

  5. #5
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    sur la colonne ID l'index.

    j'ai pensé à qqchose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO `site`.`table` (`id`, `shorturl`, `longurl`) VALUES (NULL, '$shorturl', '$longurl')
    (SELECT `shorturl` FROM `site`.`table` WHERE `shorturl` NOT IN ('$shorturl'))
    syntaxe erreur que ça dit.

    Citation Envoyé par stealth35 Voir le message
    il faut bien mettre tes indexes, visiblement shorturl doit avoir un index UNIQUE, tu l'as bien mis ?

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par dancom5 Voir le message
    sur la colonne ID l'index.
    ça c'est l'index PRIMARY KEY
    tu dois mette un autre index UNIQUE sur ta colonne shorturl

  7. #7
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    #1062 - Duplicate entry 'face' for key 'shorturl'

    Le ID est primaire et unique.
    Je ne peux pas le modifier.

    SHORTURL j ai pu mettre index mais pas unique.


    Citation Envoyé par stealth35 Voir le message
    ça c'est l'index PRIMARY KEY
    tu dois mette un autre index UNIQUE sur ta colonne shorturl

  8. #8
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par dancom5 Voir le message
    #1062 - Duplicate entry 'face' for key 'shorturl'
    c'est bon tu peux faire ton IGNORE maintenant

  9. #9
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Tu es OK que par rapport a ta question, stealth35 t'indique comment organiser ta table pour n'avoir pour tout tes ajouts qu'une seule instruction et sans erreurs

    Si au contraire tu préféres rester a ta question d'origine, tu n'y coupes pas d'un minimum de deux requétes
    un SELECT puis l'INSERT !

  10. #10
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    Je souhaiterai plus faire un test d'existance de la clé en utilisant mysql.

    Placer un INDEX UNIQUE sur le champ 'shofturl', ça ne fonctionne pas.
    Il est déjà dans le champ ID.

    IGNORE ne marche pas non plus.

    Citation Envoyé par christele_r Voir le message
    Bonjour,
    Tu es OK que par rapport a ta question, stealth35 t'indique comment organiser ta table pour n'avoir pour tout tes ajouts qu'une seule instruction et sans erreurs

    Si au contraire tu préféres rester a ta question d'origine, tu n'y coupes pas d'un minimum de deux requétes
    un SELECT puis l'INSERT !

  11. #11
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par dancom5 Voir le message
    Placer un INDEX UNIQUE sur le champ 'shofturl', ça ne fonctionne pas.
    Il est déjà dans le champ ID.
    on peux mettre autant d'index que le l'on veut dans une table, sais tu vraiment a quoi sert un index ?

  12. #12
    Invité
    Invité(e)
    Par défaut
    Oui tout les champs ne peuvent étres mis en UNIQUE, en effet les binaires sont bien sur refusés, il te faut des type CHAR VARCHAR INT etc...
    Quelle est la nature de shofturl

  13. #13
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    Il est VARCHAR

    Je revise ce tutoriel :
    http://sqlpro.developpez.com/cours/sqlaz/dml/#L1.5

    Selon ce que j'ai lu, on ne peut pas faire de sous-requête avec INSERT
    sous MYSQL.

    J'utilise Mysql 5.0.55



    Citation Envoyé par christele_r Voir le message
    Oui tout les champs ne peuvent étres mis en UNIQUE, en effet les binaires sont bien sur refusés, il te faut des type CHAR VARCHAR INT etc...
    Quelle est la nature de shofturl

  14. #14
    Invité
    Invité(e)
    Par défaut
    Donc sans aucun probleme tu peux faire (s'il nexiste pas encore) si non ça le créerait inutilement en double
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ALTER TABLE `tatable` ADD UNIQUE (`shofturl` )
    dans ton SQL ou par MySql
    Mais le piége (et il me semble que tu es dans ce cas), est si ta table a déjas sur ce champ des doublons tu aura un message d'erreur bien sur !
    Il faut en premier nettoyer ta table

  15. #15
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    Effectivement, ma table avait déjà des doublons. Je ne pouvais pas ajouter UNIQUE. mais je suis obligé de mettre INSERT IGNORE INTO?

    Citation Envoyé par christele_r Voir le message
    Donc sans aucun probleme tu peux faire (s'il nexiste pas encore) si non ça le créerait inutilement en double
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ALTER TABLE `tatable` ADD UNIQUE (`shofturl` )
    dans ton SQL ou par MySql
    Mais le piége (et il me semble que tu es dans ce cas), est si ta table a déjas sur ce champ des doublons tu aura un message d'erreur bien sur !
    Il faut en premier nettoyer ta table

  16. #16
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    ok.. je viens de comprendre.

    INSERT IGNORE INTO va permette d'ignorer un message d'erreur.
    UNIQUE va permette de ne pas avoir de doublon dans la table.

    Je viens de tester.

    Mais, si je mets pas INDEX "IGNORE", j'aimerais bien pouvoir personnaliser le message d'erreur envoyé par mysql.

  17. #17
    Invité
    Invité(e)
    Par défaut
    Quand tu aura pour une de tes tables
    1) viré les doublons pour un champ
    2) fais un ALTER etc .... pour rendre le champ unique,

    Alors tu pourras faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <?php
    $Flag1=mysql_connect("localhost","root","");
    $Flag2=mysql_select_db("tadatabase");
    $result=mysql_query("INSERT IGNORE INTO test (pseudo ) VALUES ('froufrou')");
    $x=mysql_affected_rows($Flag1);
    // $x==1 si creation OK $x==0 si doublon===== donc
    if ($x==1) echo "blablabla esr ok";
     
    ?>
    Dernière modification par Invité ; 05/10/2011 à 17h11.

  18. #18
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    J'utilise MYSQLI alors mysql_affected_rows() ça ne marche pas.
    J'utilise une alternative qui est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     $addto = $mysqli->query("INSERT INTO ...");
     
       if (!$addto) {
         $errormessage='Errormessage: '.$mysqli->error;
       }else{
       $errormessage='Confirmation: '.strtoupper($shorturl).' is Succesfully registred';
    			}
    J'aurais bien aimé l'utiliser par contre.

    mysqli :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $mysqli = new mysqli("localhost", ..");
    $mysqli->select_db('site');
    }

  19. #19
    Invité
    Invité(e)
    Par défaut variante PDO
    Je viens de tester si PDO laissait passer le retour d'info, la réponse est OUI
    Donc dans les conditions identiques de cle uniques etc...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     
    $req = $bdd->prepare("INSERT IGNORE INTO `test` (`pseudo`) VALUES (:lepseudo)");
    $x=$req->execute(array( ':lepseudo' => "hijklmn"));
    $ID=$bdd->lastInsertId();
    Pour PDO $ID reçoit 0 si pas créé car doublon
    ou la valeur de l'index auto-incrementé si succés
    même valeur donc que $bdd->lastInsertId();

    HOP YHIS HELP !

  20. #20
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    Citation Envoyé par dancom5 Voir le message
    J'utilise MYSQLI alors mysql_affected_rows() ça ne marche pas.
    http://www.php.net/manual/fr/mysqli.affected-rows.php

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Existence dans une table d'un champ entré
    Par spleak dans le forum Access
    Réponses: 1
    Dernier message: 27/01/2007, 15h56
  2. Controle existence dans une table
    Par Daniel MOREAU dans le forum Access
    Réponses: 2
    Dernier message: 15/05/2006, 13h59
  3. Réponses: 2
    Dernier message: 06/05/2006, 22h50
  4. Réponses: 7
    Dernier message: 05/05/2006, 19h55
  5. test d'existence d'une table dans une bd mysql
    Par kafana dans le forum JDBC
    Réponses: 5
    Dernier message: 25/03/2006, 21h19

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