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 Firebird Discussion :

Grant sur toutes les tables en même temps


Sujet :

SQL Firebird

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 187
    Points : 69
    Points
    69
    Par défaut Grant sur toutes les tables en même temps
    Bonjour,

    Je n'arrive pas à trouver l'instruction, si elle existe, qui permet de faire un grant pour un user sur toutes les tables de ma base de donnée.

    J'utilise FIREBIRD 1.5

    Merci d'avance.

    Jer

  2. #2
    Membre expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Points : 3 712
    Points
    3 712
    Par défaut
    ça n'existe pas
    mais bon c'est pas difficile à faire.
    Philippe Makowski
    IBPhoenix - Firebird
    Membre de l'April

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 187
    Points : 69
    Points
    69
    Par défaut
    Mais comment fait-on?

    Est-ce plus facile à faire avec delphi 7?

    jer

  4. #4
    Membre expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Points : 3 712
    Points
    3 712
    Par défaut
    tu peux utiliser qqchose comme ça :
    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
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    SET TERM ^;
    CREATE PROCEDURE GRANT_PERMS
      (CMD VARCHAR(6),
       PRIV CHAR(10),
       USR VARCHAR(31),
       ROLENAME VARCHAR(31),
       GRANTOPT SMALLINT,
       CREATE_ROLE SMALLINT)
    AS
      DECLARE VARIABLE RELNAME VARCHAR(31);
      DECLARE VARIABLE EXESTRING VARCHAR(1024) = '';
      DECLARE VARIABLE EXESTUB VARCHAR(1024) = '';
    BEGIN
        IF (ROLENAME = '') THEN ROLENAME = NULL;
        IF ((ROLENAME IS NOT NULL) AND (CREATE_ROLE = 1)) THEN
        BEGIN
          EXESTUB = 'CREATE ROLE '||ROLENAME;
          EXECUTE STATEMENT EXESTUB;
          EXESTUB = '';
          USR = ROLENAME;
          ROLENAME = NULL;
        END
        IF (USR = '') THEN USR = NULL;
        IF (PRIV = '') THEN PRIV = NULL;
        IF ((PRIV IS NULL AND ROLENAME IS NULL) OR USR IS NULL) THEN EXIT;
        IF (CMD STARTING WITH 'G') THEN
          EXESTUB = 'GRANT ';
        ELSE
          EXESTUB = 'REVOKE ';
        IF (ROLENAME IS NOT NULL) THEN
        BEGIN
          IF (EXESTUB = 'GRANT') THEN
          BEGIN
            EXESTUB = EXESTUB||ROLENAME||' TO '||USR;
            IF (GRANTOPT = 1) THEN
              EXESTUB = EXESTUB||' WITH ADMIN OPTION';
          END
          ELSE
            EXESTUB = EXESTUB||ROLENAME||' FROM '||USR;
          EXECUTE STATEMENT EXESTUB;
        END
        ELSE
        BEGIN
          IF (PRIV = 'ANY') THEN
            EXESTUB = EXESTUB||'SELECT,DELETE,INSERT,UPDATE,REFERENCES ON ';
          ELSE
            EXESTUB = EXESTUB||PRIV||' ON ';
          FOR SELECT RDB$RELATION_NAME FROM RDB$RELATIONS
          WHERE RDB$RELATION_NAME NOT STARTING WITH 'RDB$'
          INTO :RELNAME DO
          BEGIN
            EXESTRING = EXESTUB||:RELNAME||' ';
            IF (CMD STARTING WITH 'G') THEN
              EXESTRING = EXESTRING||'TO ';
            ELSE
              EXESTRING = EXESTRING||'FROM ';
            EXESTRING = EXESTRING||USR;
            IF (GRANTOPT = 1) THEN
              EXESTRING = EXESTRING||' WITH GRANT OPTION';
            EXECUTE STATEMENT EXESTRING;
          END
          FOR SELECT RDB$PROCEDURE_NAME FROM RDB$PROCEDURES
          INTO :RELNAME DO
          BEGIN
            IF (CMD STARTING WITH 'G') THEN
              EXESTRING = 'GRANT EXECUTE ON PROCEDURE '||:RELNAME||' TO ';
            ELSE
              EXESTRING = 'REVOKE EXECUTE ON PROCEDURE '||:RELNAME||' FROM ';
            EXESTRING = EXESTRING||USR;
            IF (GRANTOPT = 1) THEN
              EXESTRING = EXESTRING||' WITH GRANT OPTION';
            EXECUTE STATEMENT EXESTRING;
          END
        END
    END ^
    SET TERM ;^
    COMMIT;
     
    EXECUTE PROCEDURE GRANT_PERMS('GRANT','ALL','MONUSER','',0,0);
    COMMIT;
    Philippe Makowski
    IBPhoenix - Firebird
    Membre de l'April

Discussions similaires

  1. Grant pour un utilisateur sur toutes les tables
    Par MarcS dans le forum Administration
    Réponses: 2
    Dernier message: 13/08/2009, 08h54
  2. recherche sur toutes les tables
    Par galinette dans le forum Access
    Réponses: 1
    Dernier message: 29/06/2007, 11h16
  3. Réponses: 3
    Dernier message: 14/03/2007, 17h31
  4. Réponses: 4
    Dernier message: 06/09/2006, 14h04

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