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 :

Requete SQL oracle


Sujet :

SQL Oracle

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 10
    Points : 3
    Points
    3
    Par défaut Requete SQL oracle
    Bonjour,

    je souhaite ajouter certains champs dans une table "Operation" mais je rencontre certains problèmes.
    Pourriez-vous m'aider merci:
    Voila ma commande sql :

    Le champs suivant doit être un entier positif:
    ALTER TABLE OPERATIONS ADD (CREREV INTEGER (2) IS NOT NULL);

    Les autres champs doivent etre de type boolean:
    ALTER TABLE OPERATIONS ADD (CONSTRAINT BOOL_POSTOPESURIM CHECK (OPESURIM=0 OR OPESURIM=1));
    ALTER TABLE OPERATIONS ADD (CONSTRAINT BOOL_POSTOPECESSI CHECK (OPECESSI=0 OR OPECESSI=1));
    ALTER TABLE OPERATIONS ADD (CONSTRAINT BOOL_POSTOPEEURSYS CHECK (OPEEURSYS=0 OR OPEEURSYS=1));

    Help please

  2. #2
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par el_conkeror Voir le message
    je souhaite ajouter certains champs dans une table "Operation" mais je rencontre certains problèmes.
    Serait-ce être trop indiscret que de les connaitre ?

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 10
    Points : 3
    Points
    3
    Par défaut
    Salut,

    les champs que je souhaite ajouter à la table OPERATIONS sont:
    Pour le type boolean
    OPESURIM
    OPECESSI
    OPEEURSYS

    pour le type entier positif
    CREREV

    merci

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 814
    Points
    17 814
    Par défaut
    INTEGER(2) n'est pas un format valide.
    NUMBER(2) vous assurera un entier, mais pas nécessairement positif.
    Il faut donc rajouter une contrainte pour le contrôler.

    La contrainte à la création est NOT NULL, pas IS NOT NULL.

    Je ne vois pas d'erreur sur la syntaxe du contrôle booléen, j'aurai utilité un IN et moins de parenthèse mais ça ne me paraît pas faux :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    create table operation
    (
    id       number(1),
    opesurim number(1)
    );
    -- Table created.
     
    ALTER TABLE operation
    ADD CREREV NUMBER(2) NOT NULL
    ADD CONSTRAINT ENTIER_POS_CREREV
          CHECK (CREREV >= 0)
    ADD CONSTRAINT BOOL_POSTOPESURIM
          CHECK (opesurim IN (0, 1));
    -- Table altered.
    PS : Avant d'ajouter vos contraintes, ajoutez vos colonnes !

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 10
    Points : 3
    Points
    3
    Par défaut
    Salut,

    Lorsque je passele script suivant :

    ALTER TABLE operation
    ADD CREREV NUMBER(2) NOT NULL
    ADD CONSTRAINT ENTIER_POS_CREREV CHECK (CREREV >= 0)
    ADD CONSTRAINT BOOL_POSTOPESURIM CHECK (opesurim IN (0, 1))
    ADD CONSTRAINT BOOL_POSTOPECESSI CHECK (opecessi IN (0, 1))
    ADD CONSTRAINT BOOL_POSTOPEEURSYS CHECK (opeeursys IN (0, 1));

    voila l'erreur que j'ai :
    ORA-00904: "OPESURIM": invalid identifier

    merci

  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 814
    Points
    17 814
    Par défaut
    Je m'auto-cite :
    Citation Envoyé par Waldar Voir le message
    PS : Avant d'ajouter vos contraintes, ajoutez vos colonnes !
    Donc pour vous :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    ALTER TABLE operation 
    ADD CREREV NUMBER(2) NOT NULL 
    ADD CONSTRAINT ENTIER_POS_CREREV CHECK (CREREV >= 0) 
    ADD OPESURIM NUMBER(1) NOT NULL
    ADD CONSTRAINT BOOL_POSTOPESURIM CHECK (OPESURIM IN (0, 1)) 
    ADD OPECESSI NUMBER(1) NOT NULL
    ADD CONSTRAINT BOOL_POSTOPECESSI CHECK (OPECESSI IN (0, 1)) 
    ADD OPEEURSYS NUMBER(1) NOT NULL
    ADD CONSTRAINT BOOL_POSTOPEEURSYS CHECK (OPEEURSYS IN (0, 1));

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 10
    Points : 3
    Points
    3
    Par défaut
    Merci Beaucoup

Discussions similaires

  1. requete sql oracle
    Par kwakly dans le forum SQL
    Réponses: 2
    Dernier message: 23/08/2007, 11h13
  2. Datacombo + Requetes SQL Oracle
    Par Tatoine dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 13/06/2007, 15h08
  3. DIVISION dans une requete sql ORACLE
    Par medonline dans le forum Langage SQL
    Réponses: 11
    Dernier message: 31/01/2007, 13h51
  4. Sous-requetes SQL Oracle MsQUERY
    Par CHRISTOPHE_86 dans le forum Oracle
    Réponses: 1
    Dernier message: 11/09/2006, 21h45
  5. Requete SQL Oracle
    Par Nounoursonne dans le forum Langage SQL
    Réponses: 3
    Dernier message: 19/07/2006, 12h48

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