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 :

Boucle sous PL/SQL [10g]


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Juin 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2013
    Messages : 20
    Par défaut Boucle sous PL/SQL
    Bonjour à tous,
    je cherche désespérément à stratifier un ensemble d'opération à partir d'une vue.
    La vue se compose de la manière suivante :
    OP   | date de début | date de fin  |  valeur  |  montant
    OP1  |  11/11/2012   |  11/11/2022  |   4.5    |   1 000
    OP2  |  02/04/2000   |  02/04/2020  |   1.2    |     500
    OP3  |  01/05/2010   |  10/05/2014  |   9      |   4 000
    ce que je cherche à faire est stratifier ces opérations en fonction du champ "valeur" en faisant la somme des montants de la manière suivante :
    A : somme montant pour les opérations dont "valeur" est comprise entre 0 et 0.5
    B : somme montant pour les opérations dont "valeur" est comprise entre 0.5 et 1
    C : somme montant pour les opérations dont "valeur" est comprise entre 1 et 1.5
    et ainsi de suite jusqu'à 10

    Je pensais faire un if, mais il faut que j'en fasse 20 et cela me parait assez lourd

    connaitriez vous un moyen plus simple ?

    merci

  2. #2
    Membre extrêmement actif
    Avatar de islamov2000
    Homme Profil pro
    Ingénieur d'études & developpement en informatique
    Inscrit en
    Septembre 2007
    Messages
    814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur d'études & developpement en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2007
    Messages : 814
    Billets dans le blog
    6
    Par défaut
    Qu'est ce que tu as dépensé comme effort en terme de programmation.

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Juin 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2013
    Messages : 20
    Par défaut
    Rien ne vous oblige à répondre

    J'ai commencé à travailler sur des stratifications à partir de date
    cela donne :

    Code sql : 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
    20
    21
    22
    23
    24
    select t.contract_type,
           t.contract_desc,
           t.rate,
           t.rate_value,
           t.amortizing_type,
           t.currency,
           t.attribute_1,
           t.attribute_2,
           t.family,
           sum (t.outstanding),
           '@0Y-5Y' as tb
      from ma table t
     where add_months(trunc(sysdate), 5 * 12) > t.maturity_date
       and t.date like '201009%'
    group by t.contract_type,
           t.contract_desc,
           t.rate,
           t.rate_value,
           t.amortizing_type,
           t.currency,
           t.attribute_1,
           t.attribute_2,
           t.family,
           '@0Y-5Y'

    en terme de longueur, c'est supportable puisqu'il n'y a que 3 "répétitions"
    0-5 y / 5-10 y / 10-15y

    Par contre, pour des strates plus nombreuses (dans le cas que je présente, 20), je souhaiterais savoir s'il existe d'autres moyens

    merci

  4. #4
    Membre éprouvé Avatar de Razorflak
    Homme Profil pro
    Développeur Flex/AS3
    Inscrit en
    Juin 2013
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Flex/AS3
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2013
    Messages : 97
    Par défaut
    Bonjour,
    je comprend se que tu essayes de faire mais par contre une fois que tu fait tes boucles quesque tu cherches à obtenir à la fin de ta fonction (comme tu parles de PL/SQL) ? Une chaine avec des séparateur, un tableau, ... ?

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Juin 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2013
    Messages : 20
    Par défaut
    j'aimerais récupérer sous forme de tableau avec la colonne supplémentaire mentionnant la stratification

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Février 2010
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 412
    Par défaut
    Si vous faites un truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mod(trunc(valeur * 2), 20)
    dans le group by vous aurez directement vos valeurs groupés

    1,7 deviendrait 3
    0,2 deviendrait 0
    0,6 deviendrait 1
    Etc

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

Discussions similaires

  1. problème sous-requête SQL et order by
    Par aguest dans le forum Requêtes
    Réponses: 10
    Dernier message: 26/12/2005, 23h57
  2. Sous requette sql je pense ?
    Par lotus77777 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 25/11/2005, 19h40
  3. Sous-requêtes SQL
    Par mandrake256 dans le forum WinDev
    Réponses: 6
    Dernier message: 21/06/2005, 10h15
  4. format date sous postgres sql
    Par ruppert62 dans le forum PostgreSQL
    Réponses: 9
    Dernier message: 27/05/2005, 12h04
  5. Désactiver un trigger sous MS Sql Server
    Par WOLO Laurent dans le forum Développement
    Réponses: 6
    Dernier message: 03/07/2003, 12h51

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