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 :

create type avec constraint sur colonnes


Sujet :

SQL Oracle

  1. #1
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Septembre 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 44
    Par défaut create type avec constraint sur colonnes
    je veux creer un type avec des contraintes sur ses colonnes:
    exemple:
    CREATE OR REPLACE TYPE MAJ_OBJ_ASSOC_TYPE AS OBJECT
    (
    TYPE_MAJ CHAR(1 BYTE) NULL
    , ID_TYPE_OBJ_ASS_MAJ NUMBER(10) NULL
    , ID_OBJ_ASS_MAJ NUMBER(10) NULL
    );

    alter type MAJ_OBJ_ASSOC_TYPE add (
    CONSTRAINT CK_MAJ_OBJ_ASSOC_TYPE_TYPE_MAJ CHECK TYPE_MAJ IN ('A')
    );

    le pb est que ce alter ne passe pas !?

    y a t-il une syntaxe qui peut passer ?

    A++

  2. #2
    Expert confirmé 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
    Par défaut
    Il n’est pas possible de définir de contraintes pour un type de cette façon, vérifiez la syntaxe. Par contre il est possible de définir une méthode pour vérifier l’état de l’objet et lever une exception si c’est le cas en Oracle 8 ou faire le test dans le constructeur à partir d’Oracle 9.
    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 REPLACE TYPE MAJ_OBJ_ASSOC_TYPE AS OBJECT
    ( 
      TYPE_MAJ CHAR(1) NULL, 
      ID_TYPE_OBJ_ASS_MAJ NUMBER(10) NULL, 
      ID_OBJ_ASS_MAJ NUMBER(10) NULL,
      MEMBER PROCEDURE CHECK_TYPE_MAJ
    )
    /
    CREATE OR REPLACE TYPE BODY MAJ_OBJ_ASSOC_TYPE AS
       MEMBER PROCEDURE CHECK_TYPE_MAJ IS
       BEGIN
         If TYPE_MAJ Not In ('A') Then
           Raise_Application_Error(-20000, 'Le type_Maj est incorrect');
         End If;
       END CHECK_TYPE_MAJ;
    End;
    /
    declare
      var MAJ_OBJ_ASSOC_TYPE;
    Begin
      var := MAJ_OBJ_ASSOC_TYPE('A', 1, 1);
      var.CHECK_TYPE_MAJ;            -- OK
      var := MAJ_OBJ_ASSOC_TYPE('B', 1, 1);  
      var.CHECK_TYPE_MAJ;            -- KO
    End;  
    /

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Septembre 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 44
    Par défaut
    c un peu plus compliqué à ce que je m'attendais
    mais ca me va.

    ca ressemble a de la POO ;-)

    merci bcp MNITU

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    C'est pas plus simple de créer une table temporaire ?

  5. #5
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Septembre 2007
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 44
    Par défaut
    table temporaire ?
    pourquoi faire ?

Discussions similaires

  1. [2012] creation dun tableau avec condition sur colonne est index
    Par Lafleur2012 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 25/03/2014, 10h03
  2. [AC-2003] insert into avec select sur colonne suivante
    Par nawakbling dans le forum VBA Access
    Réponses: 1
    Dernier message: 12/10/2010, 19h44
  3. [XL-2007] Somme avec multicritères sur colonne+ligne
    Par jrc11 dans le forum Excel
    Réponses: 2
    Dernier message: 03/10/2010, 22h42
  4. Probleme avec Renderer sur colonne Date
    Par touftouf57 dans le forum AWT/Swing
    Réponses: 4
    Dernier message: 19/01/2010, 02h16
  5. table avec recherche sur colonne
    Par wincroc dans le forum Général JavaScript
    Réponses: 28
    Dernier message: 31/05/2007, 11h52

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