SGBD distribué - Contrôle de base de données

Le contrôle de base de données fait référence à la tâche de faire appliquer les réglementations afin de fournir des données correctes aux utilisateurs authentiques et aux applications d'une base de données. Pour que les données correctes soient disponibles pour les utilisateurs, toutes les données doivent être conformes aux contraintes d'intégrité définies dans la base de données. En outre, les données doivent être exclues des utilisateurs non autorisés afin de maintenir la sécurité et la confidentialité de la base de données. Le contrôle de la base de données est l'une des tâches principales de l'administrateur de base de données (DBA).

Les trois dimensions du contrôle de base de données sont:

  • Authentication
  • Des droits d'accès
  • Contraintes d'intégrité

Authentification

Dans un système de base de données distribué, l'authentification est le processus par lequel seuls les utilisateurs légitimes peuvent accéder aux ressources de données.

L'authentification peut être appliquée à deux niveaux -

  • Controlling Access to Client Computer- À ce niveau, l'accès des utilisateurs est restreint lors de la connexion à l'ordinateur client qui fournit une interface utilisateur au serveur de base de données. La méthode la plus courante est une combinaison nom d'utilisateur / mot de passe. Cependant, des méthodes plus sophistiquées comme l'authentification biométrique peuvent être utilisées pour des données de haute sécurité.

  • Controlling Access to the Database Software- À ce niveau, le logiciel / l'administrateur de la base de données attribue des informations d'identification à l'utilisateur. L'utilisateur accède à la base de données à l'aide de ces informations d'identification. L'une des méthodes consiste à créer un compte de connexion dans le serveur de base de données.

Des droits d'accès

Les droits d'accès d'un utilisateur font référence aux privilèges qui lui sont accordés concernant les opérations du SGBD tels que les droits de créer une table, de supprimer une table, d'ajouter / supprimer / mettre à jour des tuples dans une table ou d'interroger sur la table.

Dans les environnements distribués, étant donné qu'il existe un grand nombre de tables et un plus grand nombre d'utilisateurs, il n'est pas possible d'attribuer des droits d'accès individuels aux utilisateurs. Ainsi, DDBMS définit certains rôles. Un rôle est une construction avec certains privilèges dans un système de base de données. Une fois les différents rôles définis, les utilisateurs individuels se voient attribuer l'un de ces rôles. Souvent, une hiérarchie des rôles est définie en fonction de la hiérarchie d'autorité et de responsabilité de l'organisation.

Par exemple, les instructions SQL suivantes créent un rôle «Comptable», puis attribuent ce rôle à l'utilisateur «ABC».

CREATE ROLE ACCOUNTANT; 
GRANT SELECT, INSERT, UPDATE ON EMP_SAL TO ACCOUNTANT; 
GRANT INSERT, UPDATE, DELETE ON TENDER TO ACCOUNTANT; 
GRANT INSERT, SELECT ON EXPENSE TO ACCOUNTANT; 
COMMIT; 
GRANT ACCOUNTANT TO ABC; 
COMMIT;

Contrôle de l'intégrité sémantique

Le contrôle d'intégrité sémantique définit et applique les contraintes d'intégrité du système de base de données.

Les contraintes d'intégrité sont les suivantes -

  • Contrainte d'intégrité du type de données
  • Contrainte d'intégrité d'entité
  • Contrainte d'intégrité référentielle

Contrainte d'intégrité du type de données

Une contrainte de type de données restreint la plage de valeurs et le type d'opérations qui peuvent être appliquées au champ avec le type de données spécifié.

Par exemple, considérons qu'une table "HOSTEL" a trois champs - le numéro de l'auberge, le nom de l'auberge et la capacité. Le numéro de l'auberge doit commencer par la lettre majuscule "H" et ne peut pas être NULL, et la capacité ne doit pas être supérieure à 150. La commande SQL suivante peut être utilisée pour la définition des données -

CREATE TABLE HOSTEL ( 
   H_NO VARCHAR2(5) NOT NULL, 
   H_NAME VARCHAR2(15), 
   CAPACITY INTEGER, 
   CHECK ( H_NO LIKE 'H%'), 
   CHECK ( CAPACITY <= 150) 
);

Contrôle de l'intégrité des entités

Le contrôle d'intégrité de l'entité applique les règles afin que chaque tuple puisse être identifié de manière unique à partir d'autres tuples. Pour cela, une clé primaire est définie. Une clé primaire est un ensemble de champs minimaux qui peuvent identifier de manière unique un tuple. La contrainte d'intégrité d'entité indique que deux tuples dans une table ne peuvent pas avoir de valeurs identiques pour les clés primaires et qu'aucun champ faisant partie de la clé primaire ne peut avoir la valeur NULL.

Par exemple, dans le tableau d'auberge ci-dessus, le numéro d'auberge peut être attribué comme clé primaire via l'instruction SQL suivante (en ignorant les vérifications) -

CREATE TABLE HOSTEL ( 
   H_NO VARCHAR2(5) PRIMARY KEY, 
   H_NAME VARCHAR2(15), 
   CAPACITY INTEGER 
);

Contrainte d'intégrité référentielle

La contrainte d'intégrité référentielle définit les règles des clés étrangères. Une clé étrangère est un champ dans une table de données qui est la clé primaire d'une table associée. La contrainte d'intégrité référentielle établit la règle selon laquelle la valeur du champ de clé étrangère doit soit être parmi les valeurs de la clé primaire de la table référencée, soit être entièrement NULL.

Par exemple, considérons une table d'étudiant où un étudiant peut choisir de vivre dans une auberge. Pour inclure cela, la clé primaire de la table hostel doit être incluse en tant que clé étrangère dans la table student. L'instruction SQL suivante incorpore ceci -

CREATE TABLE STUDENT (  
   S_ROLL INTEGER PRIMARY KEY, 
   S_NAME VARCHAR2(25) NOT NULL, 
   S_COURSE VARCHAR2(10), 
   S_HOSTEL VARCHAR2(5) REFERENCES HOSTEL 
);