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

SQL Oracle Discussion :

copie de 50 millions de lignes


Sujet :

SQL Oracle

  1. #1
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 18
    Par défaut copie de 50 millions de lignes
    bonjour,
    j'ai une table partitionnée par semaine. (appelons la TF_WEEK)
    chaque semaine contient environ 12 millions de lignes.

    afin de mener une étude, j'ai besoin de faire une sélection de données sur un mois. Afin de ne pas perturber la production, je souhaite donc copier les données dont j'ai besoin dans une table à part (qu'on appelle TF_WEEK_STUDY)

    Evidemment, vu la volumétrie, un bête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    create table TF_WEEK_STUDY as select * from TF_WEEK where DATE_CMD>='01/02/2011' and DATE_CMD<='28/02/2011'
    prend un peu de temps (au bout de 12h de moulinage, j'ai laissé tombé, ou alors c'est la connexion qui m'a laissé tomber)

    Du coup, je me demandais, comme la table est partitionnée par semaine, que je connais donc le nom des partitions dont j'aurai besoin, existe-t-il un moyen rapide (moins de 10h, ça m'irait) pour copier ces données dans une table à part ?

    Merci

  2. #2
    Membre Expert Avatar de ojo77
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Décembre 2010
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2010
    Messages : 680
    Par défaut
    Je ne connais pas de moyen plus rapide que le CTAS. par contre comme tu te contente de sélectionner une partition il est possible de faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE TABLE TF_WEEK_STUDY AS SELECT * FROM TF_WEEK partition (P12)

  3. #3
    Expert confirmé
    Avatar de laurentschneider
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2005
    Messages
    2 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2005
    Messages : 2 944
    Par défaut
    si c'est partitioné par semaine, le

    WHERE DATECMD >= date '2011-04-04' and DATECMD < date '2011-04-11'

    te fera automatiquement un pruning des partitions.

    Dans 11g, il y a le INTERVAL partitioning qui t'évitera de créer les partitions à l'avance

  4. #4
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 18
    Par défaut
    Bonjour, merci pour vos réponses.
    J'aurai du préciser, suis sur oracle 10.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CREATE TABLE TF_WEEK_STUDY AS SELECT * FROM TF_WEEK partition (P12)
    avec ce code, je passe d'un cout estimé de 5 millions à 195 000.

    C'est nickel merci!

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 16/09/2007, 14h14
  2. Réponses: 1
    Dernier message: 08/03/2007, 10h47
  3. 100 million de lignes, 34 Go : partition ou autre ?
    Par Greg07 dans le forum Administration
    Réponses: 9
    Dernier message: 24/10/2006, 18h02
  4. Transferer 500 millions de lignes
    Par Kikoune dans le forum Oracle
    Réponses: 4
    Dernier message: 26/05/2006, 17h09
  5. [SELECT sur 16 millions de lignes] délai très grand
    Par localhost dans le forum Requêtes
    Réponses: 6
    Dernier message: 22/11/2004, 17h04

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