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 :

Erreur ORA-00911: caractère non valide sur l'appel d'une procédure


Sujet :

PL/SQL Oracle

  1. #1
    Membre habitué Avatar de IllusionStriker
    Profil pro
    Étudiant
    Inscrit en
    Juin 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2007
    Messages : 129
    Points : 179
    Points
    179
    Par défaut Erreur ORA-00911: caractère non valide sur l'appel d'une procédure
    bonjour a tous!
    Comme le titre l'indique j'ai une erreur sur l'appel d'une de mes procédure en pl/sql:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORA-00911: caractère non valide
    voici ma procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    create or replace procedure nouvel_utilisateur(pnom IN VARCHAR2,pmail IN VARCHAR2)
    as
    begin
    insert into utilisateur(id_utilisateur,nom,mail,inscription,nb_action)
    values (seq_utilisateur.nextval, pnom, pmail,sysdate,0);
    end;
    le code de ma procédure s'exécute sans erreur et la procédure est crée.

    voici mon appel de procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    call nouvel_utilisateur('dede','dede@mail.com');
    cependant dès que j'exécute cet appel j'ai cette erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORA-00911: caractère non valide
    help je comprends plus rien ça me rend fou
    j'ai vérifié mes tables tous les noms correspondent je comprends pas

    je suis sous oracle database express edition.

    Si quelqu'un comprends qu'il m'explique s'il vous plait....
    merci d'avance.
    Illusion
    Ne me vouvoie pas je ne suis pas supérieur à toi!
    moi je tutoie mais je vous assure que le respect y est!

  2. #2
    Membre confirmé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Points : 534
    Points
    534
    Par défaut
    Citation Envoyé par IllusionStriker Voir le message
    voici mon appel de procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    call nouvel_utilisateur('dede','dede@mail.com');
    C'est peut être le @. Essaye une insertion sans et laisse nous savoir.
    "Celui qui reconnaît consciemment ses limites est le plus proche de la perfection." Johann Wolfgang

  3. #3
    Membre habitué Avatar de IllusionStriker
    Profil pro
    Étudiant
    Inscrit en
    Juin 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2007
    Messages : 129
    Points : 179
    Points
    179
    Par défaut @ ne changeant rien
    Merci de l'intérêt porté mais avec ou sans @ le résultat est le même...cela me rend fou je ne vois pas de logique dans ce problème...
    Ne me vouvoie pas je ne suis pas supérieur à toi!
    moi je tutoie mais je vous assure que le respect y est!

  4. #4
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 108
    Points : 83
    Points
    83
    Par défaut
    EST CE QUE ORACLE EXPRESSE PERMET D'EXECUTER LES PROCEDURES?
    SINON ESSAYE DE RAJOUTER UN "/" A LA FIN DE TA PROCEDURE
    latrach.net

  5. #5
    Membre actif Avatar de DAB.cz
    Inscrit en
    Octobre 2006
    Messages
    221
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 221
    Points : 249
    Points
    249
    Par défaut
    Citation Envoyé par IllusionStriker Voir le message
    voici mon appel de procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    call nouvel_utilisateur('dede','dede@mail.com');
    Dans quelle logiciel? Ça marche sous SQL*Plus.

    j'ai vérifié mes tables tous les noms correspondent
    Donne nous le script.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORA-00911: caractère non valide
    C'est l'erreur complete?

  6. #6
    Membre habitué Avatar de IllusionStriker
    Profil pro
    Étudiant
    Inscrit en
    Juin 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2007
    Messages : 129
    Points : 179
    Points
    179
    Par défaut
    Citation Envoyé par IllusionStriker
    je suis sous oracle database express edition.
    voici mon code entier:
    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
    42
    43
    44
    45
    create table utilisateur(id_utilisateur integer primary key,
    nom varchar2(32),
    mail varchar2(64)unique,
    inscription DATE,
    nb_action integer);
     
    create table salle(id_salle integer primary key,
    theme varchar2(128),
    id_moderateur integer references 
    utilisateur(id_utilisateur),
    nb_thread integer);
     
     
    create table message(id_message integer primary key,
    id_parent integer null references message(id_message),
    id_auteur integer references utilisateur(id_utilisateur),
    date_envoi timestamp,
    id_salle integer references salle(id_salle),
    corps varchar2(512),
    etat varchar2(6)check(etat in ('ouvert','clot')));
     
    create sequence seq_utilisateur
    start with 1
    increment by 1
    NOMAXVALUE;
     
    create sequence seq_salle
    start with 1
    increment by 1
    NOMAXVALUE;
     
    create sequence seq_message
    start with 1
    increment by 1
    NOMAXVALUE;
     
     
    create or replace procedure nouvel_utilisateur(pnom IN VARCHAR2,pmail IN VARCHAR2)
    as
    begin
    insert into utilisateur(id_utilisateur,nom,mail,inscription,nb_action)
    values (seq_utilisateur.nextval, pnom, pmail,sysdate,0);
    end;
     
    call nouvel_utilisateur('dede','dede@mail.com');
    Citation Envoyé par DAB.cz
    Dans quelle logiciel? Ça marche sous SQL*Plus.
    oui je pense que cela fonctionne sous SQL*Plus je n'ais jamais eu de soucis avec malheureusement je me retrouve sous oracle database express edition...
    et oui l'erreur est entiere
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORA-00911: caractère non valide
    je patauge cette erreur va obtenir ma peau ! si seulement la description de cette erreur était un roman je suis sur que je comprendrais d'où viens ce satané problème mais la...
    merci d'avance

    Illusion
    Ne me vouvoie pas je ne suis pas supérieur à toi!
    moi je tutoie mais je vous assure que le respect y est!

  7. #7
    Membre confirmé Avatar de rvfranck
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2004
    Messages
    746
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2004
    Messages : 746
    Points : 534
    Points
    534
    Par défaut
    Ton code à l'air correct, ton problème vient certainement d'ailleurs et apparament il y'a pas grand chose à faire:
    ORA-00911: invalid character
    Cause: identifiers may not start with any ASCII character other than letters and numbers. $#_ are also allowed after the first character. Identifiers enclosed by doublequotes may contain any character other than a doublequote. Alternative quotes (q"#...#") cannot use spaces, tabs, or carriage returns as delimiters. For all other contexts, consult the SQL Language Reference Manual.
    Action: none
    Si sous sql ça marche, ton problème vient peut être de l'outil que tu utilises pour faire ton insert. Il y'a des outils qui ne permette pas d'enchainer des ordres, essaye d'executer instruction après instruction.
    "Celui qui reconnaît consciemment ses limites est le plus proche de la perfection." Johann Wolfgang

  8. #8
    Expert éminent sénior 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
    Points : 11 252
    Points
    11 252
    Par défaut
    Citation Envoyé par IllusionStriker Voir le message
    voici mon code entier:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ...
    call nouvel_utilisateur('dede','dede@mail.com');
    oui je pense que cela fonctionne sous SQL*Plus je n'ais jamais eu de soucis avec malheureusement je me retrouve sous oracle database express edition...
    et oui l'erreur est entiere
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORA-00911: caractère non valide
    ...
    Il y a un sqlplus aussi dans Oracle XE. Remplace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    call nouvel_utilisateur('dede','dede@mail.com');
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    begin nouvel_utilisateur('dede','dede@mail.com'); end;

  9. #9
    Membre habitué Avatar de IllusionStriker
    Profil pro
    Étudiant
    Inscrit en
    Juin 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2007
    Messages : 129
    Points : 179
    Points
    179
    Par défaut La solution
    Citation Envoyé par mnitu Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    begin nouvel_utilisateur('dede','dede@mail.com'); end;


    merci mnitu ta solution est la bonne !
    mais je tiens a remercier toute les personnes qui ont pris un peu de leur temps pour se pencher sur mon problème ça fait plaisir ,merci pour toute ces propositions.

    C'est curieux qu'il faille inclure l'instruction entre un 'begin' et 'end' je pari que c'est typique de l'édition express... bref cette solution fonctionne et j'avoue que je n'y aurais jamais pensé...
    Encore merci a tous et particulièrement a mnitu

    bonne continuation a tous.
    Illusion
    Ne me vouvoie pas je ne suis pas supérieur à toi!
    moi je tutoie mais je vous assure que le respect y est!

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

Discussions similaires

  1. Erreur ORA-00911: caractère non valide
    Par JCD21 dans le forum SQL
    Réponses: 3
    Dernier message: 18/08/2011, 10h47
  2. [Migration] ORA-00911: Caractère non valide en XI
    Par diidouu dans le forum Administration-Migration
    Réponses: 10
    Dernier message: 08/09/2009, 16h25
  3. Réponses: 2
    Dernier message: 15/04/2009, 07h42
  4. [10g Express] ORA-00911: caractère non valide
    Par maynoush dans le forum SQL
    Réponses: 4
    Dernier message: 23/11/2008, 16h04
  5. ORA-00911: caractère non valide
    Par Yayam dans le forum SQL
    Réponses: 5
    Dernier message: 14/11/2008, 15h42

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