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

PostgreSQL Discussion :

Imbrication des table


Sujet :

PostgreSQL

  1. #1
    Membre régulier Avatar de IMPRO
    Homme Profil pro
    Développeur décisionnel
    Inscrit en
    Août 2007
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur décisionnel

    Informations forums :
    Inscription : Août 2007
    Messages : 111
    Points : 94
    Points
    94
    Par défaut Imbrication des table
    Bonsoir,
    j'aimerai créer un type ''type_privilege" et à partir de ce type je créerai une table de ce type et mettre cette derniere dans une table que j'ai nommé utilisateur voici le code SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE TYPE "type_privilege" AS (
    	fonctionalite varchar(30),
    	etat boolean
    	);
     
    CREATE TABLE liste_privilege OF type_privilege
    CREATE TABLE utilisateur(
    	nom varchar(30),
    	prenom varchar(30),
    	priv liste_privilege
    	);
    j'aimerai savoir svp les requetes qu'il faut pour remplir la table utilisateur (INSERT) pour avoir comme résultat par exemple :
    ---------------------------------------------------
    Nom----|Prenom--------| priv----------------------|
    ------------------------|fonctionnalite |etat |
    ----------------------------------------------------
    nom1---|prenom1-------|f1--------------|true------|
    .................................|f2---------------|false------|
    ----------------------------------------------------
    et comment utiliser la contrainte default sur l'attribut priv
    merci

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bonjour,


    Je ne vais pas répondre à votre question, mais par contre en soulever une autre.


    Qu'elle est l'utilité d'affecter un privilège à un utilisateur s'il ne l'a pas ?

    Du coup niveau modélisation :
    Utilisateur-0,n-----Possède------0,n-Privilège

    => MPD
    Utilisateur (uti_id, uti_nom, ...)
    Privilege(pri_id, pri_description, ...)
    a_uti_pri (#uti_id, #pri_id)

    Comme ça vous ne stockez que les données nécessaires

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    CREATE TABLE OF type ça n'existe pas sous Postgresql, ça ressemble à du Oracle plutôt. Il n'y a pas de tables imbriquées dans Postgresql.

Discussions similaires

  1. Réponses: 4
    Dernier message: 28/09/2011, 23h06
  2. remplir des tables a partir de fichiers TXT
    Par jeremie dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 10/03/2004, 14h50
  3. Afficher noms des tables d'une base
    Par jeff37 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/01/2004, 16h00
  4. Liste des tables d'une bases de données spécifique
    Par faridos23 dans le forum Requêtes
    Réponses: 3
    Dernier message: 26/08/2003, 22h20
  5. noms des tables d'une base
    Par molto dans le forum SQL
    Réponses: 2
    Dernier message: 17/03/2003, 22h14

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