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

PL/SQL Oracle Discussion :

analyse en fonction des rows


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Inscrit en
    Avril 2006
    Messages
    702
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 702
    Points : 289
    Points
    289
    Par défaut analyse en fonction des rows
    Salut a tous
    en lisant les differents forum, j'ai capté une table de corespondance entre le pourcentage qu'il faut donner a la commande "ANALYSE" et le nombre de lignes dans la table.
    Voici cette correspondance:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Fewer than 10,000 rows: Exact calculation (COMPUTE)
    Fewer than 100,000 rows: ESTIMATE with 30 % of the table
    Fewer than 1,000,000 rows: ESTIMATE with 10 % of the table
    Fewer than 10,000,000 rows: ESTIMATE with 3 % of the table
    More than 10,000,000 rows: ESTIMATE with 1% of the table
    Vous confirmez cette table? ou avez-vous une approche differente?
    D?autre part, je voudrais avec SQL ou PL/SQL (surement plus facil en PL)
    faire une requete qui consulte les tables du shema, et en fonction du nombre de lignes, crée dynamiquement les commande ANALYSE qui correspondent.
    J'ai commencé mais je coince dans les IF, peu etre ce script existe deja...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    DECLARE 
    v_table_Name VARCHAR(50);
    v_nrow number;
    begin
    SELECT TABLE_NAME, NUM_ROWS INTO v_table_name, v_nrow
    FROM DBA_TABLES;
     
     IF v_nrow >0 AND v_nrow <10000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||TABLE_NAME||' ESTIMATE STATISTICS COMPUTE');
     ELSE
     IF v_nrow >10001 AND v_nrow <100000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||TABLE_NAME||' ESTIMATE STATISTICS SAMPLE 30 PERCENT');
     IF v_nrow >100001 AND v_nrow <1000000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||TABLE_NAME||' ESTIMATE STATISTICS SAMPLE 10 PERCENT');
     ...
    end;
    Ca marche ca?
    D'avance merci pour le coup de main

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    Bah teste le pour vérifier

    Sinon, depuis la 9i ANALYZE est remplacé par DBMS_STATS

  3. #3
    Membre actif
    Inscrit en
    Avril 2006
    Messages
    702
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 702
    Points : 289
    Points
    289
    Par défaut analyse en fonction des rows
    DBMS_STAT
    oui oui ca je savais, mais ici ils veulent pas changer pour le moment .... etrange non?
    Le script que j'ai fait tu crois que ca marche?
    J'ai l'impression qu'il manque une boucle ou qque chose pour creer un dbms_output pour chaque table existente dans la base.
    Non?

  4. #4
    Membre actif
    Inscrit en
    Avril 2006
    Messages
    702
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 702
    Points : 289
    Points
    289
    Par défaut analyse en fonction des rows
    Avec ce code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    DECLARE 
    v_table_Name VARCHAR(50);
    v_nrow NUMBER;
    BEGIN
    SELECT TABLE_NAME, NUM_ROWS INTO v_table_name, v_nrow
    FROM DBA_TABLES
    WHERE OWNER='MON_USER';
     
     IF v_nrow BETWEEN 0 AND 10000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_table_name||' ESTIMATE STATISTICS COMPUTE');
     END IF;
     IF v_nrow BETWEEN 10001 AND 100000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_table_name||' ESTIMATE STATISTICS SAMPLE 30 PERCENT');
     END IF;
     IF v_nrow BETWEEN 100001 AND 1000000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_table_name||' ESTIMATE STATISTICS SAMPLE 10 PERCENT');
     END IF;
    END;
    /
    J'ai cette erreur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ORA-01422: exact fetch returns more than requested number of rows
    ORA-06512: at line 5
    si le select renvoie plus de une ligne...alors dans ce cas il faut une boucle non? un curseur?? je nage un peu la..
    Ciao

  5. #5
    Membre actif
    Inscrit en
    Avril 2006
    Messages
    702
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 702
    Points : 289
    Points
    289
    Par défaut analyse dans script pl/sql
    Je l'ai modifier comme ceci, mais ca deconne toujours:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    DECLARE 
    v_tbl DBA_TABLES.table_name%TYPE;
    v_nrow DBA_TABLES.NUM_ROWS%TYPE;
    BEGIN
    SELECT TABLE_NAME, NUM_ROWS INTO v_tbl, v_nrow
    FROM DBA_TABLES
    WHERE OWNER='RHUTST';
     
     IF v_nrow BETWEEN 0 AND 10000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_tbl||' ESTIMATE STATISTICS COMPUTE');
     END IF;
     IF v_nrow BETWEEN 10001 AND 100000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_tbl||' ESTIMATE STATISTICS SAMPLE 30 PERCENT');
     END IF;
     IF v_nrow BETWEEN 100001 AND 1000000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||v_tbl||' ESTIMATE STATISTICS SAMPLE 10 PERCENT');
     END IF;
    END;
    /

    Erreur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ORA-01422: exact fetch returns more than requested number of rows
    ORA-06512: at line 5

  6. #6
    Membre du Club
    Inscrit en
    Octobre 2008
    Messages
    50
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 50
    Points : 56
    Points
    56
    Par défaut
    Il faut boucler sur un curseur puisqu'il y a plus d'une table dans ton schema.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    FOR c in (SELECT TABLE_NAME, NUM_ROWS
    FROM DBA_TABLES
    WHERE OWNER='RHUTST')
    LOOP
     
     IF c.NUM_ROWS BETWEEN 0 AND 10000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||c.TABLE_NAME||' ESTIMATE STATISTICS COMPUTE');
     END IF;
     IF c.NUM_ROWS BETWEEN 10001 AND 100000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||c.TABLE_NAME||' ESTIMATE STATISTICS SAMPLE 30 PERCENT');
     END IF;
     IF c.NUM_ROWS BETWEEN 100001 AND 1000000 THEN
     DBMS_OUTPUT.PUT_LINE('ANALYZE '||c.TABLE_NAME||' ESTIMATE STATISTICS SAMPLE 10 PERCENT');
     END IF;
    END LOOP;

Discussions similaires

  1. affichage dynamique en fonction des données en base
    Par jengo dans le forum Bases de données
    Réponses: 1
    Dernier message: 28/10/2004, 10h22
  2. remplir une table en fonction des résultats
    Par Psychomantis dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 19/10/2004, 12h22
  3. Ajusté les Axes d'un graphe en fonction des données rentrée!
    Par Ma2thieu dans le forum Composants VCL
    Réponses: 5
    Dernier message: 09/07/2004, 01h34
  4. [CR] mise en forme d'un champs texte en fonction des données
    Par niPrM dans le forum SAP Crystal Reports
    Réponses: 6
    Dernier message: 29/06/2004, 11h57
  5. sélection des bd en fonction des utilisateurs (pg_hba.conf)
    Par Bouboubou dans le forum PostgreSQL
    Réponses: 9
    Dernier message: 18/03/2004, 18h34

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