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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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

+ 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