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 :

Sondage en ligne: quelle organisation pour les tables? [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut Sondage en ligne: quelle organisation pour les tables?
    Bonjour,

    je dois réaliser des sondages et je m'interroge sur la meilleur structure à donner à mes tables, afin de pouvoir traiter les réponses de manière optimale, en utilisant le moins de requêtes possible.

    Je pense faire un table Question avec plusieurs champs:
    • ID_Question
    • Question_texte (libellé de la question)
    • Question_type (Radio, box...)


    Une table réponse comme ceci:
    • ID_Reponse
    • ID_Question
    • Reponse (libellé de chaque réponse proposée)



    Pour ma table votes, les contraintes sont: connaitre le résultat de chaque votant, et extraire des résultats sous la forme de pourcentages. Ma table ressemblerait à ca:

    • ID_votant
    • Q1 (Réponse à la Q1)
    • Q2 (Réponse à la Q2)
    • ...
    • Q10


    En procédant ainsi, pour chaque personne qui rempli le questionnaire, une seule requête permet d'enregistrer les réponses à toutes les questions. Par contre pour traiter les réponses, ca va nécessiter beaucoup de requêtes, une requête pour chaque valeur à chaque question! Du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    'select count(Q1) as q1_rep_1 From votes where Q1=1'
    'select count(Q1) as q1_rep_2 From votes where Q1=2'
    'select count(Q1) as q1_rep_3 From votes where Q1=3'
    'select count(Q2) as q2_rep_4 From votes where Q1=4'
    'select count(Q2) as q2_rep_5 From votes where Q1=5'
    'select count(Q2) as q2_rep_6 From votes where Q1=6'
    ....

    du coup je me demande si il y a pas un moyen d'optimiser ca, soit par des requêtes SQL "élaborées", mais je pense surtout en organisant ses tables différement. J'ai retourné la question dans ma tête sans arriver à une réponse qui me satisfasse, j'en appelle donc à vos lumières!

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Ta table vote doit etre :

    ID_vote
    ID_questionnaire
    ID_votant
    ID_reponse
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut
    Salut,

    merci pour ta réponse mais je ne vois pas bien comment faire..??

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Je reprends un peu ce que j'ai dit hier :

    une table questionnaire :
    ID_questionnaire
    ID_votant
    date etc.

    une table pour les votes :
    ID_vote
    ID_questionnaire
    ID_reponse
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut
    Alors oui je comprends ce que tu dis, mais je ne vois pas ce que ca change concernant le traitement des réponses et le nombre de requêtes nécessaires...

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    La repartition par réponse s'obtiens en une seule requête :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    Select ID_reponse,count(*) FROM vote WHERE id_questionnaire = 2 GROUP_BY ID_reponse
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut
    ouais nickel .. Par contre c'est quand même une requête par question, si j'ai 20 questions j'aurai 20 requêtes..

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    La requête que je t'ai mise recolte les réponses de plusieurs questions.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut
    euh en fait non.. Le point noir de cette organisation n'est donc plus la consultation des résultats mais l'enregistrement.. Si j'ai 20 questions (donc au moins 20 réponses), j'aurai au moins 20 requêtes pour enregistrer chacune de mes réponses

    Pour que ce soit plus clair, voila ma base actuelle

    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
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
     
    -- phpMyAdmin SQL Dump
    -- version 3.2.1
    -- http://www.phpmyadmin.net
    --
    -- Serveur: localhost
    -- Généré le : Jeu 08 Avril 2010 à 13:04
    -- Version du serveur: 5.1.43
    -- Version de PHP: 5.3.0
     
    SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
     
    --
    -- Base de données: `Formulaire`
    --
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `question`
    --
     
    CREATE TABLE IF NOT EXISTS `question` (
      `Id_Question` smallint(20) NOT NULL AUTO_INCREMENT,
      `question` text NOT NULL,
      `type` varchar(32) NOT NULL,
      PRIMARY KEY (`Id_Question`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
     
    --
    -- Contenu de la table `question`
    --
     
    INSERT INTO `question` (`Id_Question`, `question`, `type`) VALUES
    (1, 'Quel est votre sexe?', ''),
    (2, 'De quelle ville venez-vous?', '');
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `reponses`
    --
     
    CREATE TABLE IF NOT EXISTS `reponses` (
      `Id_Reponse` smallint(20) NOT NULL AUTO_INCREMENT,
      `Id_Q` smallint(20) NOT NULL,
      `Reponse` text NOT NULL,
      PRIMARY KEY (`Id_Reponse`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=6 ;
     
    --
    -- Contenu de la table `reponses`
    --
     
    INSERT INTO `reponses` (`Id_Reponse`, `Id_Q`, `Reponse`) VALUES
    (1, 1, 'homme'),
    (2, 1, 'femme'),
    (3, 2, 'mars'),
    (4, 2, 'Paris'),
    (5, 2, 'lyon');
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `votes`
    --
     
    CREATE TABLE IF NOT EXISTS `votes` (
      `Id_Vote` int(200) NOT NULL,
      `Id_Q` smallint(20) NOT NULL,
      `Id_R` smallint(20) NOT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1;
     
    --
    -- Contenu de la table `votes`
    --
     
    INSERT INTO `votes` (`Id_Vote`, `Id_Q`, `Id_R`) VALUES
    (0, 1, 1),
    (0, 1, 1),
    (0, 1, 2),
    (0, 1, 1),
    (0, 2, 3),
    (0, 2, 3),
    (0, 2, 4),
    (0, 2, 5),
    (0, 2, 3),
    (0, 2, 3);
    et mon script pour traiter les résultats

    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
     
    $questions=mysql_query('select * from question ');
    while ($resut_Q = mysql_fetch_array($questions)){
     
    $retour = mysql_query('SELECT Id_R,count(*) as total FROM votes WHERE id_Q = '.$resut_Q['Id_Question'].' GROUP BY Id_R');
    $total=0;
    echo"<p>QUESTION ". $resut_Q['Id_Question']."<p>"; 
    while ($sondage = mysql_fetch_array($retour)) // On fait une boucle pour lister les news
    {
     echo "Réponse ".$sondage['Id_R'].": ".$sondage['total']."<br>";
    				$total+=$sondage['total'];?></h3>
    <?php
    }
    echo"TOTAL: ". $total;
    }

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    j'aurai au moins 20 requêtes pour enregistrer chacune de mes réponses
    oui une ligne par reponse, une vraie structure relationnelle.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    100
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 100
    Par défaut
    Ok merci, j'ai juste peur de charger le serveur avec trop de requêtes (à vrai dire je n'ai aucune idée du nombre de requêtes qu'il faut pour surcharger un serveur "de base")..

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

Discussions similaires

  1. alter table pour les tables innodb
    Par slyfer dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 11/10/2006, 13h42
  2. alias ou synonymes pour les tables ou les champs ?
    Par nanou9999 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 16/03/2006, 11h04
  3. [ASA] Quelle extention pour les fichiers de données?
    Par Goldorak2 dans le forum SQL Anywhere
    Réponses: 2
    Dernier message: 07/12/2005, 09h28

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