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 :

Une étude de cas pas simple


Sujet :

Requêtes MySQL

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Une étude de cas pas simple
    Bonjour le forum,

    J'ai une grosse (30 ans) expérience en matière de bdd mais disons un peu vert avec MySQL (2 ans d'expérience) et parfaitement à l'ais een php. Voila pour le contexte.

    J'ai un cas à soumettre aux "velus" en mysql.

    Une table avec une volumétrie d'environ 50.000 à 100.000 records comportant un champ texte de 200 caractères de la forme :

    "00111010001100010001 ... 1100000101"

    Chaque octet correspond a un critère positionné à OUI (1) ou non (0). Et bien sur j'aimerais pouvoir lancer des recherche de type :

    (criteres[3] == '1') AND (critères[155] == '1')

    Pour le moment, j'envisage de passer par une table de type crosse-ref avec un champ cle qui contient le rang (1 à 200) et derrière un champs texte inventoriant les fiches concernés ...

    0 --> 17, 23, 156, 345, 1674, 13002, 45767
    1 --> nnn, nnn, nnn

    Cette suite étant utilsée ensuite avec des recherche de type IN ...avec probablement une petite routine d'intersection des séries pour ne faire qu'un seul IN final ...

    Pas de difficulté en soit sauf que comme cette série de critère peut etre assez souvent modifiée, cela va passer par un processus assez lourd de maintenance de la crossref (suppression des 1 disparus et insertions des 1 apparus ... pas très glop ...).

    Ma question : Voyez-vous une solution propre aux capacités du sql pour éviter cette usine ... et permettre ce type de recherche ?

    Merci par avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,

    en normalisant vos données :

    Une table du type :
    Choix_uti(id_uti mediumint, id_option mediumint, actif tinyint)

    Avec 100.000 utilisateurs et 200 options :
    100.000*200 ( 4 + 4 +1) = 180.000.000 octets soit 171Mo

    On index ceci et plus de probleme de perf lors des recherche, ni de mise à jour unitaire.

Discussions similaires

  1. Réponses: 2
    Dernier message: 28/05/2015, 14h27
  2. Le format Blu-Ray s'imposera-t-il ? "Pas avant 2013" dit une étude de iSuppli
    Par Pierre Louis Chevalier dans le forum Actualités
    Réponses: 118
    Dernier message: 10/01/2010, 21h34
  3. Assigner une fonction à une classe? Pas simple!
    Par Spidyy dans le forum Langage
    Réponses: 23
    Dernier message: 10/09/2009, 19h36
  4. 2 questions dans une étude de cas
    Par L'aigle de Carthage dans le forum Débuter
    Réponses: 1
    Dernier message: 01/10/2008, 14h50
  5. Réponses: 10
    Dernier message: 26/01/2008, 19h01

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