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 :

Optimisation de requêtes volumineuses


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2009
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2009
    Messages : 171
    Par défaut Optimisation de requêtes volumineuses
    Bonjour à tous,

    J'ai une table volumineuse (20 millions d'enregistrements) contenant l'ensemble des datas que mon entreprise souhaite contrôler à l'aide de règles.

    Pour chaque règle, je vais partir de cette table et contrôler chaque enregistrement. Je souhaite n'avoir que le minimum d'informations dans cette table (Id et quelques filtres), et je vais donc être obligé de faire des jointures sur les différentes tables qui vont me permettre de récupérer les données complémentaires. Je créerais ces différentes tables au fur et à mesure.

    Ma question : Comment optimiser mes tables au maximum afin d'avoir des temps de traitements raisonnables ?

    Merci d'avance pour vos conseils !

  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
    C'est un peu vague comme question. Sans plus d'infos je ne saurais que vous renvoyer vers la 3ème forme normale.

    Ensuite s'il existe des affinités entre vos tables et des regroupements simples, vous pouvez envisager du partitionnement afin de réduire le nombre de données sur lesquelles vous travaillez simultanément.

  3. #3
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 462
    Par défaut
    20 millions de lignes, ce n'est pas forcément la mer à boire : selon le nombre et le type des colonnes, ça peut loger en moins de 2 Go.

    Comme le suggère Ojo, on commence par la modélisation, les choix physiques arrivent plus tard (partitionnement, compression, index bitmap, etc).
    Ces choix physiques vont découler du type de manipulation qu'on sera amené à faire sur les données.

    C'est pour ça qu'il faut savoir comment "vivent" vos données.
    Si elles sont en lecture seule (et éventuellement alimentées par lots une fois par nuit), ce n'est pas la même chose que si vous faites du transactionnel sur ces données.

    N'oubliez pas de préciser systématiquement votre version d'Oracle, car les possibilités ne sont pas les mêmes d'une version à l'autre.
    Il sera aussi utile de savoir si vous êtes en édition Entreprise ou pas, car nombre de fonctionnalités en dépendent, voire constituent des options payantes qui se greffent sur l'édition Entreprise.

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2009
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2009
    Messages : 171
    Par défaut
    Merci beaucoup pour vos réponses, effectivement il va falloir dans un premier temps bien effectuer la modélisation.

    Il s'agit d'un projet de data governance.
    Toutes les semaines tourneront un certain nombre de règles (actuellement une 50aines). Toutes les semaines les tables seront droppées et recréées, c'est vraiment des tables propres à mon service.

    En fait le soucis n'est pas tellement le volume en lui même, mais surtout la complexité de la récupération des erreurs en fonction des règles. Une règle qui n'a qu'une jointure à faire depuis la table à 20Millions de lignes, ok pas de soucis.
    Une règle qui va nécessité d'aller faire des jointures sur 6 ou 7 tables différentes, elle va nous faire exploser le temps de traitement.
    C'est pour cela que je cherche le maximum d'informations avant de commencer à mettre en place tout cela.

    Edit : la version d'oracle est 11.1

  5. #5
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par Bouga74 Voir le message
    ...Une règle qui n'a qu'une jointure à faire depuis la table à 20Millions de lignes, ok pas de soucis.
    Une règle qui va nécessité d'aller faire des jointures sur 6 ou 7 tables différentes, elle va nous faire exploser le temps de traitement.
    ...
    Les bases des données existent pour faire des jointures !

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2009
    Messages
    171
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2009
    Messages : 171
    Par défaut
    ... merci ...

    Ma question concernait l'optimisation au maximum de ces requêtes et de mes tables et non la possibilité de le faire ou pas.

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

Discussions similaires

  1. Architecture optimisée pour requête dans table volumineuse
    Par Bouga74 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 08/02/2013, 14h52
  2. Optimiser une requête ORDER BY sur une table volumineuse
    Par micaz dans le forum Administration
    Réponses: 4
    Dernier message: 19/01/2010, 02h19
  3. Optimiser une requête SQL d'un moteur de recherche
    Par kibodio dans le forum Langage SQL
    Réponses: 2
    Dernier message: 06/03/2005, 21h55
  4. optimisation des requêtes
    Par yech dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 21/09/2004, 20h03
  5. Optimisation de requête
    Par olivierN dans le forum SQL
    Réponses: 10
    Dernier message: 16/12/2003, 11h09

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