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

Requêtes MySQL Discussion :

mysql rand() ne fonctionne pas


Sujet :

Requêtes MySQL

  1. #1
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut mysql rand() ne fonctionne pas
    Bonjour à tous,

    J'aimerais sélectionner un résultat aléatoire sur une ligne de la table avec une clause where...mais ça me retourne toujours le 1er résultat...

    ma table est présentée comme suit:
    id | data1 | data2 | data3 | data4 | data5 |

    Voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $sql = mysql_query("SELECT data1,data2,data3,data4,data5
    FROM table WHERE id='$id' order by rand() limit 1");
    while($row = mysql_fetch_row($sql)){
    echo $row[0];
    }
    Et donc, au lieu d'être une dataX au hasard, c'est toujours data1 qui sort. Si quelqu'un voit pourquoi...merci de son coup de pouce.
    Bonne journée à tous.

  2. #2
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $chiffre = rand(1, 5);
     
    $colonne = 'data' . $chiffre;
     
    $donnee = mysql_query("SELECT $colonne FROM table WHERE id='$id'");

  3. #3
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    Merci à toi, c'est parfait !
    Bonne journée

  4. #4
    Membre averti Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Points : 436
    Points
    436
    Par défaut
    oh, si, juste un truc...comment faire pour que si un champ data n'est pas renseigné (vide) , il ne sorte pas dans la recherche aléatoire.
    J'ai fait

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    $chiffre = rand(1, 5);
    $colonne = 'data' . $chiffre;
    $sql = mysql_query("SELECT $colonne FROM table WHERE id='$id' order by rand()");
    while($row = mysql_fetch_row($sql)){
    if($row[0] != '' &&  $row[0] != 0){
    echo $row[0];
    }
    }
    Mais malgré ça, les résultats vides sont quand même retournés...

  5. #5
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut
    j'comprends pas ta requête et ce que tu en fais

    where id=$id => tu dois avoir que un résultat donc ta boucle sert à rien, ton if non plus
    (si bien sur ton champ id est une clé primaire)

    order by rand() => heu... tu peux faire des order by sur un nom de champ ou sur le numéro du champ dans ta liste des champs sélectionnés et après tu peux indiquer ASC ou DESC
    ton rand() là je vois pas trop la finalité et je vois pas comment ça peut accepter la requête

    pour ton soucis de résultat vide heu... j'sais pas, essaie par exemple de poser la requête dans une boucle tantque résultat vide, faire un random, envoyer requête

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

Discussions similaires

  1. [ANT / DbUnit / MySql] Import ne fonctionne pas ?
    Par pcouas dans le forum Tests et Performance
    Réponses: 1
    Dernier message: 16/01/2011, 17h48
  2. ORDER BY RAND() ne fonctionne pas dans INSERT
    Par cedrick21 dans le forum Requêtes
    Réponses: 1
    Dernier message: 17/08/2010, 11h46
  3. Fonction mysql qui ne fonctionne pas pour un ancien postgreIste
    Par floreasy dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 15/01/2008, 18h49
  4. Requete MySQL qui ne fonctionne pas
    Par bzhades dans le forum Débuter
    Réponses: 14
    Dernier message: 10/05/2007, 18h19
  5. Requete qui ne fonctionne pas sur toutes les versions de MySQL
    Par goldorax113 dans le forum Requêtes
    Réponses: 2
    Dernier message: 06/06/2006, 11h04

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