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

NoSQL Discussion :

[MongoDB][Java] TTL sur chaque élément d'un document


Sujet :

NoSQL

  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2007
    Messages
    387
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 387
    Points : 301
    Points
    301
    Par défaut [MongoDB][Java] TTL sur chaque élément d'un document
    Bonjour,

    Je souhaiterais mettre en place un TTL sur chaque élément d'une collection :
    - Message 1 ajouté le 17 janvier 2014 donc sera supprimé dans 30 jours, le 16 février 2014
    - Message 2 ajouté le 18 janvier 2014 donc sera supprimé dans 30 jours, le 15 février 2014

    J'ai vu divers liens qui présentent comment faire cela : http://blog.rasc.ch/?p=2086

    Le problème est que je n'utilise pas de "DBCollection" pour créer/insérer/supprimer des élements.
    Je passe par un "MongoTemplate" qui est "Autowired". Et pour insérer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    mongoTemplate.save(messageEntity);
    Est-il possible d'utiliser le TTL dans ce cas ?

    Merci d'avance.

    Cordialement.

    NB : version du driver mongodb :
    Groupe : org.mongodb
    Artéfact : mongo-java-driver
    Version : 2.11.3

  2. #2
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    le fait d'utiliser un TTL passe par la création d'un index TTL sur la collection.

    En mongoshell, il faut utiliser ensureIndex.

    Et apparemment mongotemplate possède cette méthode aussi :

    http://docs.spring.io/spring-data/da.../html/#d0e2730

    Il faut donc sans doute l'utiliser pour créer ton index. Sinon tu peux aussi gérer tes index en dehors de ton code métier.

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2007
    Messages
    387
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 387
    Points : 301
    Points
    301
    Par défaut
    Merci pour ton aide.

    Aussi surprenant que cela puisse paraitre, la méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    mongoTemplate.ensureIndex(...)
    n'existe pas.... Pourtant j'ai la dernière version de spring data...

    J'ai trouvé une méthode qui permette de gérer cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    BasicDBObject options = new BasicDBObject("expireAfterSeconds", 30);
    BasicDBObject dbIndex = new BasicDBObject("MESSAGE_ADDED_DATE", 1);
    mongoTemplate.getCollection("message_content").ensureIndex(dbIndex, options);
    Problème avec cette méthode : comment changer le TTL au besoin ?

    J'ai donc décidé de gérer cela directement dans MongoDB :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    db.message_content.ensureIndex( { "MESSAGE_ADDED_DATE": 1 }, { expireAfterSeconds: 604800 } )
     
    //Pour MAJ le TTL :
    db.message_content.dropIndex("MESSAGE_ADDED_DATE_1")
    db.message_content.ensureIndex({"MESSAGE_ADDED_DATE" : 1}, {expireAfterSeconds : 302400})
    Cordialement.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 11/03/2015, 16h11
  2. [XL-2010] VBA : Créer un TCD sur chaque onglet d' un document
    Par dttpedt dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 10/04/2014, 15h47
  3. Réponses: 4
    Dernier message: 20/03/2013, 19h23
  4. Préciser namespace sur chaque élément d'un xml
    Par c.soub dans le forum Format d'échange (XML, JSON...)
    Réponses: 1
    Dernier message: 29/04/2010, 14h54
  5. n INDEXs sur chaque champ ou 1 seul INDEX sur n ch
    Par fourchette dans le forum Requêtes
    Réponses: 2
    Dernier message: 22/04/2004, 11h55

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