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

Oracle Discussion :

ora 00984 curseur?


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Novembre 2010
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 24
    Par défaut ora 00984 curseur?
    Bonjour, avant tout je tiens à dire que j'ai déjà visité les précédents forums qui parlent du sujet mais je n'ai pas réussi à trouver l'erreur.Alors je sollicite juste un peu d'aide pour que mon trigger compile comme il faut.

    Voici mon 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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
     
    CREATE OR REPLACE TRIGGER MAJ_INVENTORY
    AFTER UPDATE OR INSERT ON S_ITEM
    FOR EACH ROW
    DECLARE
     
    	CURSOR C1 IS 
    	SELECT * FROM S_INVENTORY WHERE PRODUCT_ID = :NEW.PRODUCT_ID 
    	AND WAREHOUSE_ID IN ( SELECT ID FROM S_WAREHOUSE WHERE REGION_ID IN (SELECT DISTINCT REGION_ID FROM S_CUSTOMER))
    	ORDER BY AMOUNT_IN_STOCK DESC 
    	FOR UPDATE OF AMOUNT_IN_STOCK nowait; 
     
    	INVENT C1%ROWTYPE;
    	QUANT NUMBER(9) := :NEW.QUANTITY;
    	temp number;
    BEGIN
    	OPEN C1;
    		LOOP FETCH C1 INTO INVENT;
     
    		EXIT WHEN QUANT = 0 OR C1%NOTFOUND; 
     
    			IF (INVENT.AMOUNT_IN_STOCK - QUANT) > INVENT.REORDER_POINT THEN 
    			UPDATE S_INVENTORY SET AMOUNT_IN_STOCK = AMOUNT_IN_STOCK - QUANT WHERE CURRENT OF C1;
    			QUANT := 0;
     
    			ELSIF (INVENT.AMOUNT_IN_STOCK - QUANT) < INVENT.REORDER_POINT AND (INVENT.AMOUNT_IN_STOCK - QUANT) > 0 THEN 
    			QUANT := QUANT - INVENT.AMOUNT_IN_STOCK;
    			UPDATE S_INVENTORY SET AMOUNT_IN_STOCK = 0 WHERE CURRENT OF C1;
    			INSERT INTO REAPPRO VALUES(PRODUCT_ID, WAREHOUSE_ID, MAX_IN_STOCK,TO_DATE(SYSDATE,'DD/MM/RR'),NULL);
     
    			ELSIF QUANT > INVENT.MAX_IN_STOCK THEN 
    			QUANT := QUANT - INVENT.AMOUNT_IN_STOCK;
    			UPDATE S_INVENTORY SET AMOUNT_IN_STOCK = 0 WHERE CURRENT OF C1;
    			INSERT INTO REAPPRO VALUES(PRODUCT_ID, WAREHOUSE_ID,MAX_IN_STOCK,TO_DATE(SYSDATE,'DD/MM/RR'),NULL);
    			END IF;
     
    		END LOOP;
    	IF QUANT > 0 THEN 
    	RAISE_APPLICATION_ERROR(-20001,'Commande trop importante => rupture de stock');END IF;
    END;
    /
    show error :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    LINE/COL ERROR
    -------- -----------------------------------------------------------------
    25/4     PL/SQL: SQL Statement ignored
    25/57    PL/SQL: ORA-00984: Un nom de colonne n'est pas autorisé ici
    30/4     PL/SQL: SQL Statement ignored
    30/56    PL/SQL: ORA-00984: Un nom de colonne n'est pas autorisé ici

    Merci de votre aide !!

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Je dirai que le problème à lieu au niveau de vos insert, nulle part ne sont déclarées les variables PRODUCT_ID, WAREHOUSE_ID et MAX_IN_STOCK.

    Vous ne vouliez pas écrire :NEW.PRODUCT_ID, :NEW.WAREHOUSE_ID et :NEW.MAX_IN_STOCK à la place ?

    Au passage, ceci est une erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_DATE(SYSDATE,'DD/MM/RR')
    Vous convertissez une date en date, c'est inutile, écrivez juste SYSDATE.

  3. #3
    Membre averti
    Inscrit en
    Novembre 2010
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 24
    Par défaut
    Merci beaucoup, le problème est réglé. C'était une petite erreur toute bête, j'ai même honte d'avoir ouvert un forum pour cela.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 25/01/2008, 17h24
  2. Réponses: 4
    Dernier message: 10/07/2007, 15h43
  3. [PL/SQL] ORA-01001: curseur non valide
    Par sider_winder dans le forum SQL
    Réponses: 1
    Dernier message: 03/05/2007, 09h37
  4. [SQLException] ORA-00984
    Par arsenik7 dans le forum Oracle
    Réponses: 4
    Dernier message: 03/02/2006, 19h48
  5. [RESULTSET]ORA-001000 trop de curseurs ouverts
    Par elitost dans le forum JDBC
    Réponses: 7
    Dernier message: 30/06/2005, 13h54

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