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 :

Historique éléments lus et non lus [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé Avatar de windmastr26
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    234
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2009
    Messages : 234
    Par défaut Historique éléments lus et non lus
    Salut à tous,

    Je suis en train d'essayer d'améliorer les capacités d'un de mes sites et surtout de réduire les traitements et transactions avec la BD.

    A cet effet, j'aimerai savoir comment vous faites pour gérer les "éléments non lus" et "lus" par les utilisateurs ?

    Pour ma part, j'ai créé une table "aConsulter", et à chaque ajout d'une donnée sur le site (article, post, photo, etc.), j'insère une entrée dans cette table pour chaque utilisateur enregistré dans ma BD :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    TABLE aConsulter
    type varchar(50) (ex. : forum, photo, article, etc.)
    idUser int
    idElt int
    dateHeure int
    lorsque l'utilisateur se rend sur la fiche de l'élément en question, l'enregistrement correspondant se supprime de la table aConsulter. Il dispose aussi d'options "marquer tous comme lus" pour tout supprimer.

    Mais avec le temps, je me demande s'il n'existe pas une autre méthode !! En effet, plus il y a d'utilisateurs inscrits, plus la table devient lourde (à chaque post, 2500 entrées dans aConsulter, puis encore 2500 à chaque photo, etc, ...).

    Comment procédez-vous de votre coté ? Avez-vous une méthode plus simple ?

  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
    Ca serait plus economique de faire l'inverse : inscrire les articles que l'utilisateur a lu.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé Avatar de windmastr26
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    234
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2009
    Messages : 234
    Par défaut
    Merci pour la suggestion , mais bon la table risque tout de même d'être assez importante au final. Je cherchais un autre moyen, peut être n'afficher les éléments comme non lus que s'ils remontent à moins de 30 jours, et du coup supprimer ceux de la table aConsulter correspondants. Comme ça on conserve un historique des éléments lus que sous 30 jours et on limite la taille de la table.

    Seul inconvénient : ceux qui ne se sont pas connectés depuis un mois...

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

Discussions similaires

  1. forum : gérer les messages lus et non lus avec un cookie
    Par elcoyotos dans le forum Langage
    Réponses: 2
    Dernier message: 18/08/2014, 14h30
  2. Détecter les emails non lus
    Par mico2 dans le forum Composants VCL
    Réponses: 3
    Dernier message: 15/03/2006, 21h19
  3. Messages "non lus" qui restent non-lus?
    Par Médinoc dans le forum Mode d'emploi & aide aux nouveaux
    Réponses: 6
    Dernier message: 04/11/2005, 18h41

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