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 Firebird Discussion :

Erreur dans une requete


Sujet :

SQL Firebird

  1. #1
    Nouveau membre du Club
    Erreur dans une requete
    Salut
    quel est le probleme avec ma requete

    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
    20
    21
    22
     
    CREATE OR ALTER  procedure test( a integer)
    as
     
    begin
    select
        floor(a.RANKNO / :a) as GROUPNO,
        (a.RANKNO / :a) as TEST123,
        a.RANKNO,
        a.id,
        a.nom,
        a.note
    from
        (
    SELECT
                row_number() over(order by note DESC)-1 as RANKNO,
                id,
                nom,
                note
            FROM
                student) a
    end

  2. #2
    Rédacteur/Modérateur

    Bonjour,

    1 - le fait que a soit à la fois un paramètre et un alias de table est dérangeant
    2 - étrange aussi que la procédure ne renvoie aucun résultat

    plus généralement il manque un SUSPEND;

    et enfin, c'est tout personnel, mais je n'aime pas les FROM (SELECT ...) j'y préfère largement l'utilisation de CTE

    sans trop chercher à comprendre, en imaginant quel pourrait être la taille de certaines colonnes de sorties voici comment j'écrirais cette procédure
    (écriture à la volée non testée par manque de structure de table et jeu d'essai)

    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
    20
    21
    22
    23
    24
    25
    26
    27
    CREATE OR ALTER  procedure test( a integer)
    RETURNING (  GROUPNO Integer,
                       TEST123 NUMERIC(5,2),
                       RANKNO INTEGER,
                       ID INTEGER,
                       NOM VARCHAR(30),
                       NOTE INTEGER) 
    AS
    BEGIN
    FOR 
    WITH S1 AS (SELECT
                row_number() over(order by note DESC)-1 as RANKNO,
                id,
                nom,
                note
            FROM
                student)
     
    SELECT  floor(RANKNO / :a) ,
        (RANKNO / :a) ,
        RANKNO,
        id,
        nom,
        note
    from S1 INTO :GROUPNO,:TEST123,:RANKNO,:ID,:NOM,:NOTE 
    DO SUSPEND;
    END^
    La seule chose absolue dans un monde comme le nôtre, c'est l'humour. » Albert Einstein

    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Tokyo, Rio) et peut être quelques autres
    SGBD : Firebird 2.5, 3, SQLite
    générateurs Etats : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Ubuntu, Androïd

  3. #3
    Nouveau membre du Club
    merci beaucoup pour votre aide