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

PostgreSQL Discussion :

Base sur plusieurs disques


Sujet :

PostgreSQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    77
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 77
    Points : 39
    Points
    39
    Par défaut Base sur plusieurs disques
    Bonjour,
    Je cherche à spécifier où mettre les données de ma base.
    Par exemple, j'ai 2 tables A et B qui sont liés par une clef primaire/étrangère.
    Je voudrais mettre les données de A sur un disque et mettre B sur un autre disque.

    Le second probleme est que je voudrais que les données de B soient sur un disque dur externe (par USB/Firewire)

    Il me semble que j'avais vu dans la doc de Postgres qu'il était possible de faire tout ceci mais je ne retrouve plus où (ou alors, je me suis planté et ça n'existe pas )

    ->Postgres 8.2
    ->FreeBSD 6.2


    Edit1:
    J'ai retrouvé un
    passage
    du manuel

    J'ai donc testé la commande :
    "ALTER TABLE qwerty SET TABLESPACE local;"
    Lorsque j'insére des données, elles se trouvent bien dans le repertoire defini par local.
    Si je refais
    "ALTER TABLE qwerty SET TABLESPACE distant;"
    Postgres copie les données se trouvant sur local vers distant, et EFFACE ceux dans local .... pas glop (surtout que la table devra contenir plus de 500Go de données)

    Y a t'il un moyen de ne pas passer par la case couper/coller des données?


    Si je manipule un disque externe que je branche avant de lancer la base de donnée, alors je ne passe pas par l'étape "ALTER TABLE ...". Comment va réagir Postgres si je change de disque et donc de données (en conservant la même arborescence, mais des données differentes)? Le changement de disque sera transparent pour lui? ()

  2. #2
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    77
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 77
    Points : 39
    Points
    39
    Par défaut
    J'ai trouvé une solution, mais ça m'a l'air d'etre un peu trop bourrin :
    1) On sauvegarde quelque part l'arborescence de la table avec des données vide
    2) On manipule B
    3) On arrete le service Postgres
    4) On change le disque
    5) On y écrit l'arborescence de B avec ses données vides
    6) On demarre le service Postgres
    7) On manipule B qui est vide

    Et pour revenir aux anciennes données, on revient à l'étape 3) sans passer par 5)

    je manipule en brut les données de Postgres. Ca m'a donc l'air d'être vraiment trop bourrin (mais ça à l'air de fonctionner quand même!). et l'air de rien, je ne manque pas d'air

    Vous n'avez pas une meilleure solution?

Discussions similaires

  1. swap sur plusieurs disques dur
    Par xlurp dans le forum Matériel
    Réponses: 8
    Dernier message: 22/12/2006, 16h48
  2. Répartition de bases sur plusieurs sites
    Par KinF dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 30/10/2006, 17h36
  3. Réponses: 6
    Dernier message: 15/02/2006, 19h29
  4. avoir des tables sur plusieurs disques ??
    Par reski dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/02/2006, 16h26
  5. Organisation physique de 2 bases sur 3 disques
    Par wazar dans le forum Oracle
    Réponses: 7
    Dernier message: 05/02/2005, 10h38

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