Guide rapide DB2

Ce chapitre décrit l'historique de DB2, ses versions, éditions et leurs fonctionnalités respectives.

Aperçu

DB2 est un produit de base de données d'IBM. Il s'agit d'un système de gestion de base de données relationnelle (SGBDR). DB2 est conçu pour stocker, analyser et récupérer efficacement les données. Le produit DB2 est étendu avec la prise en charge de fonctionnalités orientées objet et de structures non relationnelles avec XML.

L'histoire

Initialement, IBM avait développé le produit DB2 pour sa plate-forme spécifique. Depuis 1990, il a décidé de développer un serveur DB2 Universal Database (UDB), qui peut fonctionner sur tous les systèmes d'exploitation faisant autorité tels que Linux, UNIX et Windows.

Versions

Pour IBM DB2, la version actuelle UDB est 10.5 avec les fonctionnalités de BLU Acceleration et son nom de code comme «Kepler». Toutes les versions de DB2 à ce jour sont répertoriées ci-dessous:

Version Nom de code
3.4 Araignée
8.1, 8.2 Stinger
9,1 Vipère
9,5 Vipère 2
9.7 Cobra
9,8 Il a ajouté des fonctionnalités avec Only PureScale
10.1 Galilée
10,5 Kepler

Éditions et fonctionnalités du serveur de données

En fonction des exigences des fonctionnalités nécessaires de DB2, les organisations sélectionnent la version DB2 appropriée. Le tableau suivant présente les éditions du serveur DB2 et leurs fonctionnalités:

Éditions traits
Advanced Enterprise Server Edition et Enterprise Server Edition (AESE / ESE) Il est conçu pour les entreprises de taille moyenne à grande. Plate-forme - Linux, UNIX et Windows. Partitionnement de tables High Availability Disaster Recovery (HARD) Materialized Query Table (MQT) Multidimensional Clustering (MDC) Concentrateur de connexions Compression de sauvegarde Pure XML Fédérations homogènes
Édition Workgroup Server (WSE) Il est conçu pour les groupes de travail ou les entreprises de taille moyenne. En utilisant ce WSE, vous pouvez travailler avec - Réorganisation en ligne de reprise après sinistre haute disponibilité (HARD) Prise en charge de la fédération de services Web Pure XML
Express -C Il fournit toutes les fonctionnalités de DB2 sans frais. Il peut fonctionner sur n'importe quel système physique ou virtuel avec n'importe quelle taille de configuration.
Edition Express Il est conçu pour les entreprises débutantes et de taille moyenne. Il s'agit d'un serveur de données DB2 complet. Il n'offre que des services limités. Cette édition est fournie avec - Fédérations de services Web Fédérations homogènes DB2 Réplications SQL homogènes Compression de sauvegarde
Édition développeur d'entreprise Il ne propose qu'un seul développeur d'application. Il est utile de concevoir, construire et prototyper les applications pour un déploiement sur n'importe quel serveur IBM. Le logiciel ne peut pas être utilisé pour développer des applications.

Ce chapitre décrit les étapes d'installation du serveur DB2.

introduction

Vous pouvez télécharger la version d'évaluation du serveur DB2 ou acheter la licence du produit sur www.ibm.com . Il existe deux serveurs DB2 distincts disponibles pour le téléchargement, en fonction de la taille du système d'exploitation sur lequel il est prévu de s'exécuter. Par exemple, si vous souhaitez télécharger un serveur DB2 pour un système d'exploitation Linux ou UNIX 32 bits, vous devez télécharger un serveur DB2 32 bits. Il en va de même pour le serveur DB2 64 bits.

Exigences matérielles

Processeur: Minimum Core 2Duo

Ram: 1 Go minimum

Disque dur: 30 Go minimum

Logiciels requis

Avant d'installer le serveur DB2, votre système doit être prêt avec le logiciel requis. Pour Linux, vous devez installer «libstdc ++ 6.0».

Vérification de la compatibilité du système

Avant d'installer DB2 Server, vous devez vérifier si votre système est compatible avec le serveur DB2. Pour confirmer la compatibilité, vous devez appeler la commande 'db2prereqcheck' sur la console de commande.

Installation de DB2 sur le système d'exploitation Linux

Ouvrez le terminal et définissez le chemin du dossier d'image d'installation db2 sur la console à l'aide de la commande «CD <dossier d'installation DB2>». Tapez ensuite la commande «./db2prereqcheck», qui confirme la compatibilité de votre système avec le serveur DB2.

./db2prereqcheck

La figure 1 montre les exigences de compatibilité du système d'exploitation Linux et du système matériel.

Suivez les étapes indiquées pour installer DB2 sur votre système Linux:

  • Ouvrez le terminal.
  • Connectez-vous en tant qu'utilisateur root.
  • Ouvrez le dossier d'installation DB2.
  • Tapez «./db2setup» et appuyez sur Entrée.

Ce processus lancera l'exécution de la configuration du serveur DB2.

Tapez «./db2setup» et appuyez sur Entrée sur le terminal racine pour démarrer le processus de configuration du serveur DB2.

Ce faisant, l'écran «Configurer Launch Pad» apparaît. [Figure 2]

Sur la page de la zone de lancement d'installation, sélectionnez l'option «Installer un produit» dans le menu de gauche. Sélectionnez l'option «DB2 Advanced Enterprise Server Edition». Sélectionnez le bouton «Installer nouveau».

Un nouveau cadre apparaît avec le nom «Assistant de configuration DB2». Cliquez sur Suivant". [Figure 3]

L'écran suivant apparaît avec le contrat de licence DB2. Sélectionnez «J'accepte les conditions…» Cliquez sur «Suivant». [Figure 4]

L'écran suivant apparaît avec une offre de type d'installation, qui est définie par défaut sur «Typique».

Gardez la même sélection. Cliquez sur Suivant". [Figure 5]

L'écran suivant apparaît avec l'action d'installation.

Sélectionnez «Installer DB2 Advanced Enterprise Server Edition…»

Cliquez sur Suivant". [Figure 6]

Sur l'écran suivant, le programme d'installation demande la sélection du répertoire d'installation.

Conservez la valeur par défaut et cliquez sur «Suivant».

L'écran suivant apparaît avec l'authentification de l'utilisateur. Entrez votre mot de passe pour l'utilisateur «dasusr1».

(Votre mot de passe peut être identique au nom d'utilisateur afin qu'il soit pratique à retenir.)

Sur l'écran suivant, le programme d'installation vous demande de créer une instance de serveur DB2.

Ici, il crée une instance DB2 avec le nom «db2inst1».

L'écran suivant vous demande le nombre de partitions dont vous avez besoin pour votre instance par défaut.

Vous avez le choix entre des partitions «simples ou multiples».

Sélectionnez «instance de partition unique». Cliquez sur Suivant".

Sur l'écran suivant, le programme d'installation vous demande une authentification pour l'instance DB2 en cours de création.

Ici, le nom d'utilisateur par défaut est créé en tant que «db2inst1». Vous pouvez entrer le même mot de passe que le nom d'utilisateur.

Cliquez sur Suivant".

Sur l'écran suivant, la configuration demande de saisir les informations d'authentification pour l'utilisateur «db2fenc».

Ici, vous pouvez entrer le même mot de passe que le nom d'utilisateur.

Cliquez sur Suivant".

Sur l'écran suivant, vous pouvez sélectionner l'option «Ne pas configurer votre serveur db2 pour envoyer des notifications à ce moment».

Cliquez sur Suivant".

L'écran suivant vous montre les informations sur la configuration de db2.

Cliquez sur «Terminer».

La procédure d'installation DB2 est terminée à ce stade.

Vérification de l'installation de DB2

Vous devez vérifier l’utilité de l’installation du serveur DB2. Une fois l'installation du serveur DB2 terminée, déconnectez-vous du mode utilisateur actuel et connectez-vous à l'utilisateur «db2inst1». Dans l'environnement utilisateur «db2inst1», vous pouvez ouvrir le terminal et exécuter les commandes suivantes pour vérifier si votre produit db2 est correctement installé ou non.

db2level

Cette commande affiche la version actuelle et le niveau de service du produit DB2 installé pour l'instance actuelle.

Syntax:

db2level

Example:

db2level

Output:

DB21085I Instance "db2inst2" uses "64" bits       
And DB2 code release "SQL10010" with level     
identifier "0201010E". Informational tokens     
are "DB2 v10.1.0.0", "s120403",     
"LINUXAMD64101", and Fix Pack "0".  
Product is installed at "/home/db2inst2/sqllib".

db2licm

Cette commande affiche toutes les informations relatives à la licence de notre produit DB2.

Syntax:

db2licm <parameter>

Example:

db2licm -l

Output:

Product name:                     "DB2 Advanced Enterprise Server Edition" 
License type:                     "Trial" 
Expiry date:                      "10/02/2014" 
Product identifier:               "db2aese" 
Version information:              "10.1"  
Product name:                     "DB2 Connect Server" 
License type:                     "Trial" 
Expiry date:                      "10/02/2014" 
Product identifier:               "db2consv" 
Version information:              "10.1"

Processeur de ligne de commande (CLP)

Le CLP peut être démarré dans l'un des trois modes:

  • Command mode: Dans ce mode, chaque commande et instruction SQL doit être précédée de «db2». Par exemple, interrogez «db2 activate database sample».

  • Interactive input mode: vous pouvez lancer ce mode en utilisant la commande «db2». Ici, vous pouvez passer des instructions SQL sans préfixe. Par exemple, «activer l'échantillon de base de données».

  • Batch mode: Ici, vous devez créer un fichier de script, qui contient toutes les requêtes SQL des exigences et enregistrer le fichier avec l'extension «.db2». Vous pouvez appeler cela en ligne de commande en utilisant la syntaxe «db2 –tf <filename.db2>».

introduction

Une instance est un environnement logique pour DB2 Database Manager. En utilisant l'instance, vous pouvez gérer les bases de données. En fonction de nos besoins, vous pouvez créer plusieurs instances sur une seule machine physique. Le contenu du répertoire Instance est:

  • Fichier de configuration du gestionnaire de base de données
  • Répertoire de la base de données système
  • Répertoire des nœuds
  • Fichier de configuration du nœud [db2nodes.cfg]
  • Fichiers de débogage, fichiers de vidage

Pour DB2 Database Server, l'instance par défaut est «DB2». Il n'est pas possible de modifier l'emplacement du répertoire d'instance après sa création. Une instance peut gérer plusieurs bases de données. Dans une instance, chaque base de données a un nom unique, son propre ensemble de tables de catalogue, de fichiers de configuration, d'autorités et de privilèges.

Architecture de l'instance dans le produit DB2

Plusieurs instances

Vous pouvez créer plusieurs instances dans un DB2Server sous Linux, UNIX et Windows. Il est possible d'installer plusieurs serveurs DB2 sur une machine physique.

Créer une instance sous Linux

Vous pouvez créer plusieurs instances sous Linux et UNIX si DB2 Server est installé en tant qu'utilisateur root. Une instance peut s'exécuter simultanément sous Linux et UNIX indépendamment. Vous pouvez travailler dans une seule instance du gestionnaire de base de données à la fois.

Un dossier Instance contient des fichiers et des dossiers de configuration de base de données. Le répertoire d'instance est stocké à différents emplacements sur Windows en fonction des versions du système d'exploitation.

Liste des instances

La commande suivante est utilisée pour lister les instances:

db2ilist

Cette commande répertorie toutes les instances disponibles sur un système.

Syntax:

db2ilist

Example:[Pour voir combien d'instances sont créées dans la copie DB2]

db2ilist

Output:

db2inst1 
db2inst2 
db2inst3

Commandes d'environnement d'instance

Ces commandes sont utiles pour travailler avec la disposition des instances dans DB2 CLI.

Obtenir l'instance

Cette commande affiche les détails de l'instance en cours d'exécution.

Syntax:

db2 get instance

Example:[Pour voir l'instance actuelle qui a activé l'utilisateur actuel]

db2 get instance

Output:

The current database manager instance is : db2inst1

Définir l'instance

Pour démarrer ou arrêter le gestionnaire de base de données d'une instance sur DB2 UDB, la commande suivante est exécutée pour l'instance actuelle.

Syntax:

set db2instance=<instance_name>

Example:[Pour organiser l'environnement «db2inst1» pour l'utilisateur actuel]

set db2instance=db2inst1

db2start

En utilisant cette commande, vous pouvez démarrer une instance. Avant cela, vous devez exécuter «set instance».

Syntax:

db2start

Example:[Pour démarrer une instance]

db2start

Output:

SQL1063N DB2START processing was successful

db2stop

À l'aide de cette commande, vous pouvez arrêter une instance en cours d'exécution.

Syntax:

db2stop

Output:

SQL1064N DB2STOP processing was successful.

Créer une instance

Voyons comment créer une nouvelle instance.

db2icrt

Si vous souhaitez créer une nouvelle instance, vous devez vous connecter avec root. L'ID d'instance n'est pas un ID racine ou un nom racine.

Voici les étapes pour créer une nouvelle instance:

Step1: Créez un utilisateur du système d'exploitation par exemple.

Syntax:

useradd -u <ID> -g <group name> -m -d <user location> <user name> 
-p <password>

Example: [Pour créer un utilisateur par exemple avec le nom 'db2inst2' dans le groupe 'db2iadm1' et le mot de passe 'db2inst2']

useradd -u 1000 -g db2iadm1 -m -d /home/db2inst2 db2inst2 -p db2inst2

Step2: Accédez au répertoire de l'instance DB2 dans l'utilisateur root pour créer une nouvelle instance.

Location:

cd /opt/ibm/db2/v10.1/instance

Step3: Créez une instance en utilisant la syntaxe ci-dessous:

Syntax:

./db2icrt -s ese -u <inst id> <instance name>

Example: [Pour créer une nouvelle instance 'db2inst2' dans l'utilisateur 'db2inst2' avec les fonctionnalités de 'ESE' (Enterprise Server Edition)]

./db2icrt -s ese -u db2inst2 db2inst2

Output:

DBI1446I The db2icrt command is running, please wait.
 ….
 ….. 
DBI1070I Program db2icrt completed successfully.

Organisation du port de communication et de l'hôte d'une instance

Modifiez le fichier / etc / services et ajoutez le numéro de port. Dans la syntaxe donnée ci-dessous, «inst_name» indique le nom de l'instance et «inst_port» indique le numéro de port de l'instance.

Syntax:

db2c_<inst name> <inst_port>/tcp

Example: [Ajout du numéro de port '50001 / tcp' pour l'instance 'db2inst2' avec la variable 'db2c_db2inst2' dans le fichier 'services']

db2c_db2inst2 50001/tcp

Syntax 1: [Mettre à jour la configuration du gestionnaire de base de données avec le nom du service. La syntaxe suivante 'svcename' indique le nom du service d'instance et 'inst_name' indique le nom de l'instance]

db2 update database manager configuration using svcename db2c_&<inst_name>

Example 1: [Mise à jour de la configuration DBM avec la variable svcename avec la valeur 'db2c_db2inst2' pour l'instance 'db2inst2'

db2 update database manager configuration using svcename db2c_db2inst2

Output

DB20000I The UPDATE DATABASE MANAGER CONFIGURATION command completed successfully.

Syntax 2: définir le protocole de communication «tcpip» pour l'instance en cours

db2set DB2COMM=tcpip

Syntax 3: [Arrêt et démarrage de l'instance actuelle pour obtenir les valeurs mises à jour de la configuration du gestionnaire de base de données]

db2stop 
db2start

Mettre à jour une instance

Vous pouvez mettre à jour une instance à l'aide de la commande suivante:

db2iupdt

Cette commande est utilisée pour mettre à jour l'instance dans la même version. Avant d'exécuter cette commande, vous devez arrêter le gestionnaire de base de données d'instance à l'aide de la commande «db2stop». La syntaxe sous «nom_inst» indique le nom de l'instance de serveur db2 précédemment publiée ou installée, que vous souhaitez mettre à jour vers une version plus récente ou une version de serveur db2 installée.

Syntax 1: Pour mettre à jour une instance en mode normal

db2iupdt <inst_name>

Example1:

./db2iupdt db2inst2

Syntax 2: Pour mettre à jour une instance en mode débogage

db2iupdt -D <inst_name>

Example

db2iupdt -D db2inst2

Mettre à niveau une instance

Vous pouvez mettre à niveau une instance de la version précédente de la copie DB2 vers la version actuelle nouvellement installée de la copie DB2.

db2iupgrade

Sur les systèmes Linux ou UNIX, cette commande se trouve dans le répertoire DB2DIR / instance. Dans les syntaxes suivantes, "nom_inst" indique la version précédente de l'instance DB2 et "nom_inst" indique l'utilisateur de l'instance de copie DB2 de la version actuellement installée.

Syntax 2:

db2iupgrade -d -k -u <inst_username> <inst_name>

Example:

db2iupgrade -d -k -u db2inst2 db2inst2

Command Parameters:

-d : Active le mode de débogage.

-k : Conserve le type d'instance de pré-mise à niveau s'il est pris en charge dans la copie DB2, à partir de laquelle vous exécutez cette commande.

Si vous utilisez la commande Super User (su) sous Linux pour db2iupgrade, vous devez émettre la commande «su» avec l'option «-».

Supprimer une instance

Vous pouvez déposer ou supprimer l'instance, qui a été créée par la commande «db2icrt».

db2idrop

Sur les systèmes d'exploitation Linux et UNIX, cette commande se trouve dans le répertoire DB2_installation_folder / instance.

Syntax: [dans la syntaxe suivante, 'inst_username' indique le nom d'utilisateur de l'instance et 'inst_name' indique le nom de l'instance]

db2idrop -u <inst_username> <inst_name>

Example: [Pour supprimer db2inst2]

./db2idrop -u db2inst2 db2inst2

Utilisation d'autres commandes avec instance

Commande pour savoir sur quelle instance DB2 nous travaillons actuellement.

Syntax 1: [pour vérifier l'instance actuelle activée par le gestionnaire de base de données]

db2 get instance

Output:

The current database manager instance is:  db2inst1

Syntax 2: [Pour voir l'instance actuelle avec les bits de fonctionnement et la version finale]

db2pd -inst | head -2

Example:

db2pd -inst | head -2

Output:

Instance db2inst1 uses 64 bits and DB2 code release SQL10010

Syntax 3: [Pour vérifier le nom de l'instance en cours de fonctionnement]

db2 select inst_name from sysibmadm.env_inst_info

Example:

db2 select inst_name from sysibmadm.env_inst_info

Output:

INST_NAME  --------------------------------------  
db2inst1              
1 record(s) selected.

Syntax: [Pour définir une nouvelle instance par défaut]

db2set db2instdef=<inst_name> -g

Example: [Pour mettre en tableau l'instance nouvellement créée comme instance par défaut]

db2set db2instdef=db2inst2 -g

Ce chapitre décrit la création, l'activation et la désactivation des bases de données avec la syntaxe associée.

Architecture de base de données

Une base de données est un ensemble de tables, de schémas, de pools de mémoire tampon, de journaux, de groupes de stockage et d'espaces de table travaillant ensemble pour gérer efficacement les opérations de base de données.

Répertoire de base de données

Le répertoire de base de données est un référentiel organisé de bases de données. Lorsque vous créez une base de données, tous les détails sur la base de données sont stockés dans un répertoire de base de données, tels que les détails des périphériques de stockage par défaut, les fichiers de configuration et la liste des tables temporaires, etc.

Le répertoire global de partition est créé dans le dossier d'instance. Ce répertoire contient toutes les informations globales relatives à la base de données. Ce répertoire global de partition est nommé NODExxxx / SQLyyy, où xxxx est le numéro de partition de données et yyy est le jeton de base de données.

Dans le répertoire global de partition, un répertoire spécifique au membre est créé. Ce répertoire contient des informations sur la base de données locale. Le répertoire spécifique au membre est nommé MEMBERxxxx où xxxx est un numéro de membre. L'environnement DB2 Enterprise Server Edition s'exécute sur un seul membre et ne possède qu'un seul annuaire spécifique à un membre. Ce répertoire spécifique à un membre est nommé de manière unique MEMBER0000.

Répertoire global partitionné

Emplacement du répertoire: <instance> / NODExxx / SQLxxx

Le répertoire partition-global contient les fichiers liés à la base de données répertoriés ci-dessous.

  • Fichiers de surveillance des événements d'écriture dans un fichier de blocage global
  • Fichiers d'informations sur l'espace table [SQLSPCS.1, SQLSPCS.2]
  • Fichiers de contrôle du groupe de stockage [SQLSGF.1, SQLSGF.2]
  • Fichiers de conteneur d'espace table temporaires. [/ chemin de stockage / /T0000011/C000000.TMP/SQL00002.MEMBER0001.TDA]
  • Fichier de configuration globale [SQLDBCONF]
  • Fichiers d'historique [DB2RHIST.ASC, DB2RHIST.BAK, DB2TSCHG.HIS, DB2TSCHG.HIS]
  • Fichiers liés à la journalisation [SQLOGCTL.GLFH.1, SQLOGCTL.GLFH.2]
  • Verrouillage des fichiers [SQLINSLK, SQLTMPLK]
  • Conteneurs de stockage automatique

Annuaire spécifique aux membres

Emplacement du répertoire: / NODExxxx / SQLxxxx / MEMBER0000

Ce répertoire contient:

  • Objets associés aux bases de données
  • Fichiers d’informations sur le pool de mémoire tampon [SQLBP.1, SQLBP.2]
  • Fichiers de surveillance des événements locaux
  • Fichiers liés à la journalisation [SQLOGCTL.LFH.1, SQLOGCTL.LFH.2, SQLOGMIR.LFH].
  • Fichiers de configuration locaux
  • Fichier de surveillance des événements de blocage. Les fichiers de contrôle détaillés des événements de blocage sont stockés dans le répertoire de base de données du nœud de catalogue en cas d'ESE et d'environnement de base de données partitionnée.

Créer une base de données

Vous pouvez créer une base de données en instance à l'aide de la commande «CREATE DATABASE». Toutes les bases de données sont créées avec le groupe de stockage par défaut «IBMSTOGROUP», qui est créé au moment de la création d'une instance. Dans DB2, toutes les tables de la base de données sont stockées dans un «tablespace», qui utilise leurs groupes de stockage respectifs.

Les privilèges de la base de données sont automatiquement définis comme PUBLIC [CREATETAB, BINDADD, CONNECT, IMPLICIT_SCHEMA et SELECT], cependant, si l'option RESTRICTIVE est présente, les privilèges ne sont pas accordés comme PUBLIC.

Créer une base de données non restrictive

Cette commande permet de créer une base de données non restrictive.

Syntax: [Pour créer une nouvelle base de données. 'nom_base_de_données' indique un nouveau nom de base de données que vous souhaitez créer.]

db2 create database <database name>

Example: [Pour créer une nouvelle base de données non restrictive avec le nom «un»]

db2 create database one

Output:

DB20000I The CREATE DATABASE command completed successfully.

Créer une base de données restrictive

Une base de données restrictive est créée lors de l'appel de cette commande.

Syntax: [Dans la syntaxe ci-dessous, "nom_base" indique le nom de la base de données.]

db2 create database <db_name> restrictive

Example: [Pour créer une nouvelle base de données restrictive avec le nom «deux»]

db2 create database two restrictive

Création d'une base de données avec un emplacement différent défini par l'utilisateur

Créez une base de données avec le groupe de stockage par défaut «IBMSTOGROUP» sur un chemin différent. Auparavant, vous avez appelé la commande «créer une base de données» sans aucun emplacement défini par l'utilisateur pour stocker ou créer une base de données à un emplacement particulier. Pour créer la base de données à l'aide de l'emplacement de base de données défini par l'utilisateur, la procédure suivante est suivie:

Syntax: [Dans la syntaxe ci-dessous, 'db_name' indique le 'nom de la base de données' et 'data_location' indique où stocker les données dans les dossiers et 'db_path_location' indique l'emplacement du pilote de 'data_location'.]

db2 create database '<db_name>' on '<data location>' dbpath on '<db_path_location>'

Example: [Pour créer une base de données nommée 'four', où les données sont stockées dans 'data1' et ce dossier est stocké dans 'dbpath1']

db2 create database four on '/data1' dbpath on '/dbpath1'

Affichage des fichiers de répertoire de base de données locale ou système

Vous exécutez cette commande pour voir la liste des répertoires disponibles dans l'instance actuelle.

Syntax:

db2 list database directory

Example:

db2 list database directory

Output:

System Database Directory  
 Number of entries in the directory = 6  
 Database 1 entry:  
 Database alias                       = FOUR  
 Database name                        = FOUR  
 Local database directory             = 
 /home/db2inst4/Desktop/dbpath  
 Database release level               = f.00  
 Comment                              =  
 Directory entry type                 = Indirect  
 Catalog database partition number    = 0  
 Alternate server hostname            =  
 Alternate server port number         =  
Database 2 entry: 
Database alias                       = SIX  
Database name                        = SIX  
Local database directory             = /home/db2inst4  
Database release level               = f.00  
Comment                              =  
Directory entry type                 = Indirect  
Catalog database partition number    = 0  
Alternate server hostname            =  
Alternate server port number         =

Activation de la base de données

Cette commande démarre tous les services nécessaires pour une base de données particulière afin que la base de données soit disponible pour l'application.

Syntax: ['db_name' indique le nom de la base de données]

db2 activate db <db_name>

Example: [Activation de la base de données 'one']

db2 activate db one

Désactiver la base de données

À l'aide de cette commande, vous pouvez arrêter les services de base de données.

Syntax:

db2 deactivate db <db_name>

Example: [Pour désactiver la base de données 'one']

db2 deactivate db one

Connexion à la base de données

Après avoir créé une base de données, pour la mettre en service, vous devez vous connecter ou démarrer la base de données.

Syntax:

db2 connect to <database name>

Example: [Pour connecter la base de données 1 à la CLI actuelle]

db2 connect to one

Output:

Database Connection Information  
 Database server        = DB2/LINUXX8664 10.1.0  
 SQL authorization ID   = DB2INST4  
 Local database alias   = ONE

Vérifier si la base de données est restrictive

Pour vérifier si cette base de données est restrictive ou non, voici la syntaxe:

Syntax: [Dans la syntaxe suivante, 'db' indique la base de données, 'cfg' indique la configuration, 'db_name' indique le nom de la base de données]

db2 get db cfg for <db_name> | grep -i restrict

Example: [Pour vérifier si 'une' base de données est restreinte ou non]

db2 get db cfg for one | grep -i restrict

Output:

Restrict access                       = NO

Configuration du gestionnaire de base de données et de la base de données

La configuration de l'instance (configuration du gestionnaire de base de données) est stockée dans un fichier nommé «db2system» et la configuration relative à la base de données est stockée dans un fichier nommé «SQLDBCON». Ces fichiers ne peuvent pas être modifiés directement. Vous pouvez modifier ces fichiers à l'aide d'outils qui appellent l'API. En utilisant le processeur de ligne de commande, vous pouvez utiliser ces commandes.

Paramètres de configuration du gestionnaire de base de données

Syntax: [Pour obtenir les informations du gestionnaire de base de données d'instance]

db2 get database manager configuration
db2 get dbm cfg

Syntax: [Pour mettre à jour le gestionnaire de base de données d'instance]

db2 update database manager configuration
db2 update dbm cfg

Syntax: [Pour réinitialiser les configurations précédentes]

db2 reset database manager configuration
db2 reset dbm cfg

Paramètres de configuration de la base de données

Syntax: [Pour obtenir les informations de la base de données]

db2 get database configuration
db2 get db cfg

Syntax: [Pour mettre à jour la configuration de la base de données]

db2 update database configuration
db2 update db cfg

Syntax: [Pour réinitialiser les valeurs précédemment configurées dans la configuration de la base de données

db2 reset database configuration
db2 reset db cfg

Syntax: [Pour vérifier la taille de la base de données active actuelle]

db2 "call get_dbsize_info(?,?,?,-1)"

Example: [Pour vérifier la taille de la base de données actuellement activée]

db2 "call get_dbsize_info(?,?,?,-1)"

Output:

Value of output parameters   
--------------------------   
Parameter Name  : SNAPSHOTTIMESTAMP   
Parameter Value : 2014-07-02-10.27.15.556775  
Parameter Name  : DATABASESIZE   
Parameter Value : 105795584  
Parameter Name  : DATABASECAPACITY   
Parameter Value : 396784705536  
Return Status = 0

Estimation de l'espace requis pour la base de données

Pour estimer la taille d'une base de données, la contribution des facteurs suivants doit être prise en compte:

  • Tables du catalogue système
  • Données de la table utilisateur
  • Données de champ long
  • Données d'objets volumineux (LOB)
  • Espace d'index
  • Espace de travail temporaire
  • Données XML
  • Espace fichier journal
  • Répertoire de la base de données locale
  • Fichiers système

Vérification des autorités de base de données

Vous pouvez utiliser la syntaxe suivante pour vérifier quelles autorités de base de données sont accordées à PUBLIC sur la base de données non restrictive.

Step 1: connectez-vous à la base de données avec l'ID utilisateur d'authentification et le mot de passe de l'instance.

Syntax: [Pour se connecter à la base de données avec un nom d'utilisateur et un mot de passe]

db2 connect to <db_name> user <userid> using <password>

Example: [Pour connecter «une» base de données avec l'ID utilisateur «db2inst4» et le mot de passe «db2inst4»]

db2 connect to one user db2inst4 using db2inst4

Output:

Database Connection Information  
 Database server        = DB2/LINUXX8664 10.1.0  
 SQL authorization ID   = DB2INST4  
 Local database alias   = ONE

Step2: Vérifier les autorités de la base de données.

Syntax: [La syntaxe ci-dessous montre le résultat des services d'autorité pour la base de données actuelle]

db2 "select substr(authority,1,25) as authority, d_user, d_group, 
d_public, role_user, role_group, role_public,d_role from table( 
sysproc.auth_list_authorities_for_authid ('public','g'))as t 
order by authority"

Example:

db2 "select substr(authority,1,25) as authority, d_user, d_group, 
d_public, role_user, role_group, role_public,d_role from table( 
sysproc.auth_list_authorities_for_authid ('PUBLIC','G'))as t 
order by authority"

Output:

AUTHORITY                 D_USER D_GROUP D_PUBLIC ROLE_USER ROLE_GROUP ROLE_PUBLIC D_ROLE  
------------------------- ------ ------- -------- --------- ---------- ----------- ------  
ACCESSCTRL                *      *       N        *         *          N           *       
BINDADD                   *      *       Y        *         *          N           *       
CONNECT                   *      *       Y        *         *          N           *       
CREATETAB                 *      *       Y        *         *          N           *       
CREATE_EXTERNAL_ROUTINE   *      *       N        *         *          N           *       
CREATE_NOT_FENCED_ROUTINE *      *       N        *         *          N           *       
CREATE_SECURE_OBJECT      *      *       N        *         *          N           *       
DATAACCESS                *      *       N        *         *          N           *       
DBADM                     *      *       N        *         *          N           *       
EXPLAIN                   *      *       N        *         *          N           *       
IMPLICIT_SCHEMA           *      *       Y        *         *          N           *       
LOAD                      *      *       N        *         *          N           *       
QUIESCE_CONNECT           *      *       N        *         *          N           *       
SECADM                    *      *       N        *         *          N           *       
SQLADM                    *      *       N        *         *          N           *       
SYSADM                    *      *       *        *         *          *           *       
SYSCTRL                   *      *       *        *         *          *           *       
SYSMAINT                  *      *       *        *         *          *           *       
SYSMON                    *      *       *        *         *          *           *       
WLMADM                    *      *       N        *         *          N           *         
20 record(s) selected.

Suppression de la base de données

À l'aide de la commande Drop, vous pouvez supprimer notre base de données du répertoire de la base de données d'instance. Cette commande peut supprimer tous ses objets, table, espaces, conteneurs et fichiers associés.

Syntax: [Pour supprimer une base de données d'une instance]

db2 drop database <db_name>

Example: [Pour supprimer la base de données 'six' de l'instance]

db2  drop database six

Output:

DB20000I The DROP DATABASE command completed successfully

Ce chapitre vous présente les Bufferpools dans la base de données.

introduction

Le pool de mémoire tampon fait partie d'un espace mémoire principal qui est alloué par le gestionnaire de base de données. Le but des pools de mémoire tampon est de mettre en cache la table et d'indexer les données du disque. Toutes les bases de données ont leurs propres pools de mémoire tampon. Un pool de mémoire tampon par défaut est créé au moment de la création de la nouvelle base de données. Il a appelé comme «IBMDEFAULTBP». Selon les besoins de l'utilisateur, il est possible de créer un certain nombre de pools de mémoire tampon. Dans le pool de mémoire tampon, le gestionnaire de base de données place les données de ligne de table sous forme de page. Cette page reste dans le pool de mémoire tampon jusqu'à l'arrêt de la base de données ou jusqu'à ce que l'espace soit écrit avec de nouvelles données. Les pages du pool de mémoire tampon, qui sont mises à jour avec des données mais ne sont pas écrites sur le disque, sont appelées pages «sales». Une fois que les pages de données mises à jour dans le pool de mémoire tampon sont écrites sur le disque, le pool de mémoire tampon est prêt à prendre d'autres données.

Relation entre les tablespaces et les pools de mémoire tampon

Chaque espace table est associé à un pool de mémoire tampon spécifique dans une base de données. Un tablespace est associé à un pool de mémoire tampon. La taille du pool de mémoire tampon et de l'espace de table doit être identique. Plusieurs pools de mémoire tampon vous permettent de configurer la mémoire utilisée par la base de données pour augmenter ses performances globales.

Tailles des pools de mémoire tampon

La taille de la page bufferpool est définie lorsque vous utilisez la commande «CREATE DATABASE». Si vous ne spécifiez pas la taille de la page, la taille de la page par défaut sera de 4 Ko. Une fois le pool de mémoire tampon créé, il n'est pas possible de modifier la taille de la page ultérieurement

Liste des pools de mémoire tampon disponibles dans le répertoire de base de données actuel

Syntax: [La syntaxe ci-dessous montre tous les pools de mémoire tampon disponibles dans la base de données]

db2 select * from syscat.bufferpools

Example: [Pour voir les pools de mémoire tampon disponibles dans la base de données actuelle]

db2 select * from syscat.bufferpools

Output:

BPNAME      BUFFERPOOLID DBPGNAME   NPAGES      PAGESIZE    ESTORE 
NUMBLOCKPAGES BLOCKSIZE   NGNAME
------------------------------------------------------------ 
IBMDEFAULTBP                                                                                                                
 1 -                                                                                                  
 -2        4096 N                  0           0 -     
 
 1 record(s) selected.

Création du pool de mémoire tampon

Pour créer un nouveau pool de mémoire tampon pour le serveur de base de données, vous avez besoin de deux paramètres à savoir, «nom du pool de mémoire tampon» et «taille de la page». La requête suivante est exécutée pour créer un nouveau pool de mémoire tampon.

Syntaxe: [Dans la syntaxe ci-dessous, 'bp_name' indique le nom du pool de mémoire tampon et 'size' indique la taille de la page que vous devez déclarer pour les pools de mémoire tampon (4K, 8K, 16K, 32K)]

db2 create bufferpool <bp_name> pagesize <size>

Example: [Pour créer un nouveau pool de mémoire tampon avec le nom «bpnew» et la taille «8192» (8 Ko).]

db2 create bufferpool bpnew pagesize 8192

Output

DB20000I The SQL command completed successfully.

Suppression du pool de mémoire tampon

Avant de supprimer le pool de mémoire tampon, il est nécessaire de vérifier si un espace table lui est affecté.

Syntax: [Pour supprimer le pool de mémoire tampon]

drop bufferpool <bp_name>

Example: [Pour supprimer 'bpnew' nommé bufferpool]

db2 drop bufferpool bpnew

Output

DB20000I The SQL command completed successfully.

Ce chapitre décrit les tablespaces en détail

introduction

Un espace table est une structure de stockage, il contient des tables, des index, des objets volumineux et des données longues. Il peut être utilisé pour organiser les données d'une base de données dans un groupe de stockage logique lié à l'emplacement des données stockées sur un système. Ces tablespaces sont stockés dans des groupes de partitions de base de données

Avantages des tablespaces dans la base de données

Les espaces table sont utiles dans la base de données de différentes manières, comme suit:

Recoverability: Les tablespaces facilitent les opérations de sauvegarde et de restauration. À l'aide d'une seule commande, vous pouvez effectuer une sauvegarde ou restaurer tous les objets de base de données dans les tablespaces.

Automatic storage Management: Le gestionnaire de base de données crée et étend des conteneurs en fonction des besoins.

Memory utilization: Un seul pool de mémoire tampon peut gérer plusieurs tablespaces. Vous pouvez affecter des tablespaces temporaires à leur propre pool de mémoire tampon pour augmenter les performances des activités telles que les tris ou les jointures.

Récipient

Les tablespaces contiennent un ou plusieurs conteneurs. Un conteneur peut être un nom de répertoire, un nom de périphérique ou un nom de fichier. Dans une base de données, un seul tablespace peut avoir plusieurs conteneurs sur le même périphérique de stockage physique. Si le tablespace est créé avec l'option de stockage automatique des tablespace, la création et la gestion des conteneurs sont gérées automatiquement par le gestionnaire de base de données. S'il n'est pas créé avec l'option d'espace de table de stockage automatique, vous devez définir et gérer vous-même les conteneurs.

Espaces de table par défaut

Lorsque vous créez une nouvelle base de données, le gestionnaire de base de données crée des tablespaces par défaut pour la base de données. Ces tablespace sont utilisés comme stockage pour les données utilisateur et temporaires. Chaque base de données doit contenir au moins trois tablespaces comme indiqué ici:

  1. Espace de table du catalogue
  2. Espace de table utilisateur
  3. Espace table temporaire

Catalog tablespace: Il contient des tables de catalogue système pour la base de données. Il est nommé SYSCATSPACE et ne peut pas être supprimé.

User tablespace: Ce tablespace contient des tables définies par l'utilisateur. Dans une base de données, nous avons un espace de table utilisateur par défaut, nommé USERSPACE1. Si vous ne spécifiez pas d'espace de table défini par l'utilisateur pour une table au moment de sa création, le gestionnaire de base de données choisit l'espace de table utilisateur par défaut pour vous.

Temporary tablespace: Un tablespace temporaire contient des données de table temporaires. Cet espace table contient des tablespaces temporaires système ou des tablespace temporaires utilisateur.

L'espace de table temporaire du système contient les données temporaires requises par le gestionnaire de base de données lors de l'exécution d'opérations telles que des tris ou des jointures. Une base de données doit avoir au moins un tablespace temporaire système et elle est nommée TEMPSPACE1. Il est créé au moment de la création de la base de données. L'espace de table temporaire de l'utilisateur contient les données temporaires des tables. Il est créé avec l'instruction DECLARE GLOBAL TEMPORARY TABLE ou CREATE GLOBAL TEMPORARY TABLE. Cet espace table temporaire n'est pas créé par défaut au moment de la création de la base de données.

Tablespaces and storage management:

Les tablespaces peuvent être configurés de différentes manières, selon la manière dont vous souhaitez les utiliser. Vous pouvez configurer le système d'exploitation pour gérer l'allocation de tablespace, vous pouvez laisser le gestionnaire de base de données allouer de l'espace ou vous pouvez choisir l'allocation automatique de tablespace pour vos données.

Les trois types d'espaces gérés suivants sont disponibles:

System Managed Space (SMS): Le gestionnaire du système de fichiers du système d'exploitation alloue et gère l'espace où la table est stockée. L'espace de stockage est alloué à la demande. Ce modèle se compose de fichiers représentant des objets de base de données. Ce type d'espace de table est obsolète dans la version 10.1 pour les espaces de table définis par l'utilisateur, et n'est pas obsolète pour les espaces de table catalogue et temporaires.

Database Managed Space (DMS): Le serveur de base de données contrôle l'espace de stockage. L'espace de stockage est préalloué sur le système de fichiers en fonction de la définition de conteneur que vous spécifiez lorsque vous créez l'espace table DMS. Il est obsolète depuis le groupe de correctifs 1 de la version 10.1 pour les tablespaces définis par l'utilisateur, mais il n'est pas obsolète pour les tablespace système et les tablespace temporaires.

Automatic Storage Tablespace: Le serveur de base de données peut être géré automatiquement. Le serveur de base de données crée et étend les conteneurs dépendent des données de la base de données. Avec la gestion automatique du stockage, il n'est pas nécessaire de fournir des définitions de conteneur. Le serveur de base de données s'occupe de la création et de l'extension des conteneurs pour utiliser le stockage alloué à la base de données. Si vous ajoutez de l'espace de stockage à un groupe de stockage, de nouveaux conteneurs sont automatiquement créés lorsque le conteneur existant atteint sa capacité maximale. Si vous souhaitez utiliser immédiatement le stockage nouvellement ajouté, vous pouvez rééquilibrer le tablespace.

Page, table and tablespace size:

DMS temporaire et espaces de table de stockage automatique, la taille de page que vous choisissez pour votre base de données détermine la limite maximale de la taille de l'espace de table. Pour les tables SMS de table et les tablespaces de stockage automatique temporaire, la taille de la page limite la taille de la table elle-même. Les tailles de page peuvent être de 4 Ko, 8 Ko, 16 Ko ou 32 Ko.

Type d'espace disque logique Limite de taille de page 4K Limite de taille de page 8K Limite de taille de page 16K Limite de taille de page de 32 Ko
DMS, tablespace de stockage automatique non temporaire régulier 64G 128G 256G 512G
DMS, DMS temporaire et espace de table de stockage automatique non temporaire grand 1892G 16384G 32768G 65536G

Ce chapitre décrit les groupes de stockage de base de données.

introduction

Un ensemble de chemins de stockage pour stocker la table ou les objets de la base de données est un groupe de stockage. Vous pouvez affecter les tablespaces au groupe de stockage. Lorsque vous créez une base de données, tous les tablespaces utilisent storagegorup par défaut. Le groupe de stockage par défaut pour une base de données est «IBMSTOGROUP». Lorsque vous créez une nouvelle base de données, le groupe de stockage par défaut est actif, si vous passez le paramètre «AUTOMATIC STOGROUP NO» à la fin de la commande «CREATE DATABASE». La base de données n'a pas de groupes de stockage par défaut.

Liste des groupes de stockage

Vous pouvez répertorier tous les groupes de stockage de la base de données.

Syntax: [Pour voir la liste des groupes de stockage disponibles dans la base de données actuelle]

db2 select * from syscat.stogroups

Example: [Pour voir la liste des stockages disponibles dans la base de données actuelle]

db2 select * from syscat.stogroups

Créer un groupe de stockage

Voici une syntaxe pour créer un groupe de stockage dans la base de données:

Syntax: [Pour créer un nouveau stogroup. Le 'nom_stogropu' indique le nom du nouveau groupe de stockage et 'chemin' indique l'emplacement où les données (tables) sont stockées]

db2 create stogroup 
      
        on ‘path’ 
      

Example: [Pour créer un nouveau stogroup 'stg1' sur le chemin du dossier 'data1']

db2 create stogroup stg1 on ‘/data1’

Output:

DB20000I The SQL command completed succesfully

Création d'un tablespace avec stogroup

Voici comment vous pouvez créer un tablespace avec storegroup:

Syntax: [Pour créer un nouvel espace de table à l'aide du groupe de stockage existant]

db2 create tablespace <tablespace_name>  using stogroup <stogroup_name>

Example: [Pour créer un nouvel espace table nommé 'ts1' en utilisant le groupe de stockage existant 'stg1']

db2 create tablespace ts1 using stogroup stg1

Output:

DB20000I The SQL command completed succesfully

Modifier un groupe de stockage

Vous pouvez modifier l'emplacement d'un groupe de magasins à l'aide de la syntaxe suivante:

Syntax: [Pour déplacer un groupe de stockage de l'ancien emplacement vers le nouvel emplacement]

db2 alter stogroup 
      
        add ‘location’, ‘location’ 
      

Example: [Pour modifier le chemin de l'emplacement de l'ancien emplacement vers le nouvel emplacement pour le groupe de stockage nommé 'sg1']

db2 alter stogroup sg1 add ‘/path/data3’, ‘/path/data4’

Suppression du chemin du dossier du groupe de stockage

Avant de supprimer le chemin du dossier du groupe de stockage, vous pouvez ajouter un nouvel emplacement pour le groupe de stockage à l'aide de la commande alter.

Syntax: [Pour supprimer l'ancien chemin de l'emplacement du groupe de stockage]

db2 alter stogroup 
      
        drop ‘/path’ 
      

Example: [Pour supprimer l'emplacement du groupe de stockage de «stg1»]

db2 alter stogroup stg1 drop ‘/path/data1’

Rééquilibrer un tablespace

Le rééquilibrage du tablespace est nécessaire lorsque nous créons un nouveau dossier pour le groupe de stockage ou les tablespaces pendant que les transactions sont effectuées sur la base de données et que le tablespace devient plein. Le rééquilibrage met à jour les fichiers de configuration de la base de données avec un nouveau groupe de stockage.

Syntax: [Pour rééquilibrer le tablespace de l'ancien chemin du groupe de stockage vers le nouveau groupe de stockage]

db2 alter tablspace <ts_name> rebalance

Example: [Pour rééquilibrer]

db2 alter tablespace ts1 rebalance

Renommer un groupe de stockage

Syntax: [Pour modifier le nom du nom de stockage existant]

db2 rename stogroup <old_stg_name> to <new_stg_name>

Example: [Pour modifier le nom du groupe de stockage de «sg1» au nouveau nom «sgroup1»]

db2 rename stogroup sg1 to sgroup1

Supprimer un groupe de stockage

Step 1: Avant de supprimer un groupe de stockage, vous pouvez attribuer un groupe de stockage différent aux tablespaces.

Syntax: [Pour affecter un autre groupe de stockage à l'espace table.]

db2 alter tablspace <ts_name> using stogroup <another sto_group_name>

Example: [Pour passer d'un ancien stogroup à un nouveau stogroup nommé 'sg2' pour le tablespace 'ts1']

db2 alter tablespace ts1 using stogroup sg2

Step 2:

Syntax: [Pour supprimer le stogroup existant]

db2 drop stogorup <stogroup_name>

Example: [Pour supprimer le stogroup 'stg1' de la base de données]

db2 drop stogroup stg1

Ce chapitre présente et décrit le concept de schéma.

introduction

Un schéma est une collection d'objets nommés classés logiquement dans la base de données.

Dans une base de données, vous ne pouvez pas créer plusieurs objets de base de données avec le même nom. Pour ce faire, le schéma fournit un environnement de groupe. Vous pouvez créer plusieurs schémas dans une base de données et vous pouvez créer plusieurs objets de base de données avec le même nom, avec différents groupes de schémas.

Un schéma peut contenir des tables, des fonctions, des index, des tablespaces, des procédures, des déclencheurs, etc. Par exemple, vous créez deux schémas différents nommés «Professionnel» et «Personnel» pour une base de données «employé». Il est possible de créer deux tableaux différents avec le même nom «Employé». Dans cet environnement, une table contient des informations professionnelles et l'autre des informations personnelles sur l'employé. Bien qu'ils aient deux tables avec le même nom, ils ont deux schémas différents «Personnel» et «Professionnel». Par conséquent, l'utilisateur peut travailler avec les deux sans rencontrer de problème. Cette fonctionnalité est utile lorsqu'il existe des contraintes sur la dénomination des tables.

Voyons quelques commandes liées à Schema:

Obtenir le schéma actuellement actif

Syntax:

db2 get schema

Example: [Pour obtenir le schéma de base de données actuel]

db2 get schema

Définition d'un autre schéma sur l'environnement actuel

Syntax:

db2 set schema=<schema_name>

Example: [Pour organiser 'schema1' dans l'environnement d'instance actuel]

db2 set schema=schema1

Créer un nouveau schéma

Syntax: [Pour créer un nouveau schéma avec un ID utilisateur autorisé]

db2 create schema <schema_name> authroization <inst_user>

Example: [Pour créer le schéma «schema1» autorisé avec «db2inst2»]

db2 create schema schema1 authorization db2inst2

Exercice

Créons deux tables différentes avec le même nom mais deux schémas différents. Ici, vous créez une table des employés avec deux schémas différents, l'un pour les informations personnelles et l'autre pour les informations professionnelles.

Step 1: Créez deux schémas.

Schema 1: [Pour créer un schéma nommé professionnel]

db2 create schema professional authorization db2inst2

Schema 2: [Pour créer un schéma nommé personnel]

db2 create schema personal authorization db2inst2

Step 2: Créez deux tables avec le même nom pour les détails de l'employé

Table1: professionnel.employé

[Pour créer une nouvelle table «employé» dans la base de données en utilisant le nom de schéma «professionnel»]

db2 create table professional.employee(id number, name 
varchar(20), profession varchar(20), join_date date, 
salary number);

Table2: personnel.employé

[Pour créer une nouvelle table «employé» dans la même base de données, avec le nom de schéma «personnel»]

db2 create table personal.employee(id number, name 
varchar(20), d_birth date, phone bigint, address 
varchar(200));

Après avoir exécuté ces étapes, vous obtenez deux tables avec le même nom «employé», avec deux schémas différents.

Ce chapitre présente différents types de données utilisés dans DB2.

introduction

Dans les tables DB2 Database, chaque colonne a son propre type de données en fonction des besoins du développeur. Le type de données est le type et la plage des valeurs dans les colonnes d'une table.

Types de données intégrés

  • Datetime
    • TIME: Il représente l'heure de la journée en heures, minutes et secondes.
    • TIMESTAMP: Il représente sept valeurs de la date et de l'heure sous forme d'année, de mois, de jour, d'heures, de minutes, de secondes et de microsecondes.
    • DATE: Il représente la date du jour en trois parties sous forme d'année, de mois et de jour.
  • String
    • Character
  • CHAR (fixed length): Longueur fixe des chaînes de caractères.
    • Longueur variable
  • VARCHAR: Chaînes de caractères de longueur variable.
  • CLOB: chaînes d'objet volumineuses, vous l'utilisez lorsqu'une chaîne de caractères peut dépasser les limites du type de données VARCHAR.
    • Graphic
  • GRAPHIC
    • Fixed length: Chaînes graphiques de longueur fixe contenant des caractères codés sur deux octets
    • Longueur variable
  • VARGRAPHIC: Chaîne graphique de caractères variables contenant des caractères à double bye.
  • DBCLOB: type d'objet grand
    • Binary
  • BLOB (longueur variable): chaîne binaire dans un grand objet
  • BOOLEAN: Sous la forme de 0 et 1.
  • Signed numeric
    • Exact
  • Binary integer
    • SMALLINT [16BIT]: En utilisant cela, vous pouvez insérer de petites valeurs int dans les colonnes
    • INTEGER [32BIT]: En utilisant cela, vous pouvez insérer de grandes valeurs int dans les colonnes
    • BIGINT [64BIT]: En utilisant cela, vous pouvez insérer des valeurs int plus grandes dans les colonnes
  • Decimal
    • DECIMAL (emballé)
    • DECFLOAT (virgule flottante décimale): En utilisant cela, vous pouvez insérer des nombres décimaux à virgule flottante
    • Approximate
  • Floating points
    • REAL (simple précision): à l'aide de ce type de données, vous pouvez insérer des nombres à virgule flottante simple précision.
    • DOUBLE (double précision): à l'aide de ce type de données, vous pouvez insérer des nombres à virgule flottante double précision.
  • eXtensible Mark-up Language
    • XML: Vous pouvez stocker des données XML dans cette colonne de type de données.

Les tables sont une structure logique maintenue par le gestionnaire de base de données. Dans un tableau, chaque bloc vertical est appelé comme colonne (Tuple) et chaque bloc horizontal appelé comme ligne (Entité). La collecte de données stockées sous forme de colonnes et de lignes est appelée table. Dans les tableaux, chaque colonne a un type de données différent. Les tables sont utilisées pour stocker des données persistantes.

Type de tables

  • Base Tables: Ils contiennent des données persistantes. Il existe différents types de tables de base, notamment:
    • Regular Tables: Tables à usage général, Les tables communes avec index sont des tables à usage général.
    • Multidimensional Clustering Table (MDC): Ce type de table était physiquement regroupé sur plusieurs clés et utilisé pour maintenir de grands environnements de base de données. Ces types de tables ne sont pas pris en charge dans DB2 pureScale.
    • Insert time clustering Table (ITC): Comme pour les tables MDC, les lignes sont regroupées au moment où elles sont insérées dans les tables. Ils peuvent être des tables partitionnées. Eux aussi, ne prennent pas en charge l'environnement pureScale.
    • Range-Clustered tables Table (RCT): Ces types de tableaux permettent un accès rapide et direct aux données. Ceux-ci sont implémentés sous forme de clusters séquentiels. Chaque enregistrement de la table a un ID d'enregistrement. Ces types de tables sont utilisés lorsque les données sont regroupées étroitement avec une ou plusieurs colonnes dans la table. Ce type de tables n'est pas non plus pris en charge dans DB2 pureScale.
    • Partitioned Tables: Ces types de tables sont utilisés dans le schéma d'organisation des données, dans lequel les données de table sont divisées en plusieurs objets de stockage. Les partitions de données peuvent être ajoutées, attachées et détachées d'une table partitionnée. Vous pouvez stocker plusieurs partitions de données à partir d'une table dans un espace de table.
    • Temporal Tables: L'historique d'une table dans une base de données est stocké dans des tables temporelles telles que les détails des modifications effectuées précédemment.
  • Temporary Tables: Pour le travail temporaire de différentes opérations de base de données, vous devez utiliser des tables temporaires. Les tables temporaires (DGTT) n'apparaissent pas dans le catalogue système, les colonnes XML ne peuvent pas être utilisées dans les tables temporaires créées.
  • Materialized Query Tables: MQT peut être utilisé pour améliorer les performances des requêtes. Ces types de tables sont définis par une requête, qui est utilisée pour déterminer les données dans les tables.

Créer des tableaux

La syntaxe suivante crée une table:

Syntax: [Pour créer une nouvelle table]

db2 create table <schema_name>.<table_name>
(column_name column_type....) in <tablespace_name>

Example: Nous créons une table pour stocker les détails «employé» dans le schéma de «professionnel». Cette table a des champs «id, nom, jobrole, joindate, salaire» et ces données de table seraient stockées dans le tablespace «ts1».

db2 create table professional.employee(id int, name 
varchar(50),jobrole varchar(30),joindate date, 
salary double) in ts1

Output:

DB20000I The SQL command completed successfully.

Liste des détails du tableau

La syntaxe suivante est utilisée pour répertorier les détails de la table:

Syntax: [Pour voir la liste des tables créées avec des schémas]

db2 select tabname, tabschema, tbspace from syscat.tables

Example: [Pour voir la liste des tables de la base de données courante]

db2 select tabname, tabschema, tbspace from syscat.tables

Output:

TABNAME      TABSCHEMA     TBSPACE 
------------ ------------- -------- 
EMPLOYEE     PROFESSIONAL    TS1  


 1 record(s) selected.

Liste des colonnes dans un tableau

La syntaxe suivante répertorie les colonnes d'un tableau:

Syntax: [Pour afficher les colonnes et les types de données d'un tableau]

db2 describe table <table_name>

Example: [Pour voir les colonnes et les types de données de la table 'employé']

db2 describe table professional.employee

Output:

Data type                   Column 
Column name  schema    Data type name    Length    Scale Nulls 
------ ----- --------- ----------------- --------- ----- ------ 
ID           SYSIBM    INTEGER             4         0     Yes 
NAME         SYSIBM    VARCHAR             50        0     Yes 
JOBROLE      SYSIBM    VARCHAR             30        0     Yes 
JOINDATE     SYSIBM    DATE                4         0     Yes 
SALARY       SYSIBM    DOUBLE              8         0     Yes  

  5 record(s) selected.

Colonnes masquées

Vous pouvez masquer une colonne entière d'un tableau. Si vous appelez la requête «select * from», les colonnes masquées ne sont pas renvoyées dans la table résultante. Lorsque vous insérez des données dans une table, une instruction «INSERT» sans liste de colonnes n'attend pas de valeurs pour les colonnes masquées implicitement. Ces types de colonnes sont fortement référencés dans les tables de requêtes matérialisées. Ces types de colonnes ne prennent pas en charge la création de tables temporaires.

Créer un tableau avec une colonne masquée

La syntaxe suivante crée une table avec des colonnes masquées:

Syntax: [Pour créer une table avec des colonnes masquées]

db2 create table <tab_name> (col1 datatype,col2 datatype 
implicitly hidden)

Example: [Pour créer une table «client» avec des colonnes masquées «téléphone»]

db2 create table professional.customer(custid integer not 
null, fullname varchar(100), phone char(10) 
implicitly hidden)

Insertion de valeurs de données dans un tableau

La syntaxe suivante insère des valeurs dans le tableau:

Syntax: [Pour insérer des valeurs dans un tableau]

db2 insert into <tab_name>(col1,col2,...)
 values(val1,val2,..)

Example: [Pour insérer des valeurs dans le tableau "client"]

db2 insert into professional.customer(custid, fullname, phone) 
values(100,'ravi','9898989')


db2 insert into professional.customer(custid, fullname, phone) 
values(101,'krathi','87996659')


db2 insert into professional.customer(custid, fullname, phone) 
values(102,'gopal','768678687')

Output:

DB20000I  The SQL command completed successfully.

Récupération des valeurs de la table

La syntaxe suivante récupère les valeurs de la table:

Syntax: [Pour récupérer les valeurs d'un tableau]

db2 select * from &lttab_name>

Example: [Pour récupérer les valeurs de la table 'client']

db2 select * from professional.customer

Output:

CUSTID      FULLNAME 
----------- ------------------------ 
        100 ravi
		
        101 krathi
		
        102 gopal  
		
  3 record(s) selected.

Récupération des valeurs d'une table comprenant des colonnes masquées

La syntaxe suivante récupère les valeurs des colonnes sélectionnées:

Syntax: [Pour récupérer les valeurs des colonnes masquées sélectionnées à partir d'une table]

db2 select col1,col2,col3 from <tab_name>

Example: [Pour récupérer les valeurs des colonnes sélectionnées, le résultat d'une table]

db2 select custid,fullname,phone from professional.customer

Output:

CUSTID  FULLNAME    PHONE 
------- ---------   ------------ 
100     ravi        9898989
 
101     krathi      87996659 

102     gopal       768678687 

  3 record(s) selected.

Si vous voulez voir les données dans les colonnes cachées, vous devez exécuter la commande «DESCRIBE».

Syntax:

db2 describe table <table_name> show detail

Example:

db2 describe table professional.customer show detail

Output:

Column name     Data type schema     Data type name  Column
           column    Partitionkey  code 
                                       Length   Scale    Nulls     
number     sequence      page     Hidden      Default 
--------------- -------------------- --------------- -------- ----
---- -------- ---------- ------------- -------- ----------- ------ 
---  
CUSTID          SYSIBM               INTEGER         4        0 
No       0          0         0        No 
FULLNAME        SYSIBM               VARCHAR         100      0
Yes      1          0        1208     No     

PHONE           SYSIBM               CHARACTER       10       0     
Yes      2          0             1208     Implicitly  
  
3 record(s) selected.

Modifier le type des colonnes de table

Vous pouvez modifier la structure de notre table en utilisant cette commande «alter» comme suit:

Syntax:

db2 alter table <tab_name> alter column <col_name> set data type <data_type>

Example: [Pour modifier le type de données de la colonne «id» de «int» à «bigint» pour la table des employés]

db2 alter table professional.employee alter column id set data type bigint

Output::

DB20000I The SQL command completed successfully.

Modification du nom de la colonne

Vous pouvez modifier le nom de la colonne comme indiqué ci-dessous:

Syntax: [Pour modifier le nom de la colonne de l'ancien nom au nouveau nom d'une table]

db2 alter table <tab_name> rename column <old_name> to <new_name>

Example: [Pour modifier le nom de la colonne de «fullname» à «custname» dans la table «customers».]

db2 alter table professional.customer rename column fullname to custname

Abandonner les tables

Pour supprimer une table, vous devez utiliser la commande «DROP» comme suit:

Syntax:

db2 drop table <tab_name>

Example: [Pour supprimer la base de données du formulaire de table client]

db2 drop table professional.customers

Pour supprimer toute la hiérarchie de la table (y compris les déclencheurs et la relation), vous devez utiliser la commande «DROP TABLE HIERARCHY».

Syntax:

db2 drop table hierarchy <tab_name>

Example: [Pour supprimer toute la hiérarchie d'une table "client"]

db2 drop table hierarchy professional.customers

Ce chapitre décrit la création d'alias et la récupération de données à l'aide d'alias d'objets de base de données.

introduction

Alias ​​est un nom alternatif pour les objets de base de données. Il peut être utilisé pour référencer l'objet de base de données. Vous pouvez dire que c'est un surnom pour les objets de base de données. Les alias sont définis pour que les objets rendent leur nom court, réduisant ainsi la taille de la requête et augmentant la lisibilité de la requête.

Création d'alias d'objet de base de données

Vous pouvez créer un alias d'objet de base de données comme indiqué ci-dessous:

Syntax:

db2 create alias <alias_name> for <table_name>

Example: Création d'un nom d'alias pour la table «professional.customer»

db2 create alias pro_cust for professional.customer

Si vous passez «SELECT * FROM PRO_CUST» ou «SELECT * FROM PROFESSIONAL.CUSTOMER», le serveur de base de données affichera le même résultat.

Syntax: [Pour récupérer les valeurs d'une table directement avec le nom du schéma]

db2 select * from <schema_name>.<table_name>

Example: [Pour récupérer les valeurs de la table client]

db2 select * from professional.customer

Output:

CUSTID  FULLNAME    PHONE
------- ---------   ------------ 
100     ravi        9898989 
101     krathi      87996659 
102     gopal       768678687 
  
  3 record(s) selected.

Récupération des valeurs à l'aide du nom d'alias de la table

Vous pouvez récupérer les valeurs de la base de données en utilisant le nom d'alias comme indiqué ci-dessous:

Syntax: [Pour récupérer les valeurs de la table en appelant le nom d'alias de la table]

db2 select * from <alias_name>

Example: [Pour récupérer les valeurs de la table client en utilisant le nom d'alias]

db2 select * from pro_cust

Output:

CUSTID  FULLNAME    PHONE
------- ---------   ------------ 
100     ravi        9898989 
101     krathi      87996659 
102     gopal       768678687 
  
  3 record(s) selected.

Ce chapitre décrit les différentes contraintes de la base de données.

introduction

Pour renforcer l'intégrité de la base de données, un ensemble de règles est défini, appelé contraintes. Les contraintes autorisent ou interdisent les valeurs dans les colonnes.

Dans les activités d'une base de données en temps réel, les données doivent être ajoutées avec certaines restrictions. Par exemple, dans une base de données de ventes, sales-id ou transaction-id doit être unique. Les types de contraintes sont:

  • PAS NULL
  • Unique
  • Clé primaire
  • Clé étrangère
  • Check
  • Informational

Les contraintes ne sont associées qu'aux tables. Ils ne sont appliqués qu'à des tables particulières. Ils sont définis et appliqués à la table au moment de la création de la table.

Explication de chaque contrainte:

PAS NULL

C'est une règle d'interdire les valeurs nulles d'une ou plusieurs colonnes dans la table.

Syntax:

db2 create table <table_name>(col_name col_type not null,..)

Example: [Pour créer une table de ventes, avec quatre colonnes (id, nom de l'article, quantité, prix) dans ce qui ajoute des contraintes «non nulles» à toutes les colonnes pour éviter de former une cellule nulle dans le tableau.]

db2 create table shopper.sales(id bigint not null, itemname 
varchar(40) not null, qty int not null,price double not null)

Insertion de valeurs NOT NULL dans la table

Vous pouvez insérer des valeurs dans le tableau comme indiqué ci-dessous:

Example: [ERRORoneous Query]

db2 insert into shopper.sales(id,itemname,qty) 
values(1,'raagi',12)

Output: [Requête correcte]

DB21034E  The command was processed as an SQL statement because 
it was not a 

valid Command Line Processor command.  During SQL processing 
it returned: 

SQL0407N  Assignment of a NULL value to a NOT NULL column 
"TBSPACEID=5, 

TABLEID=4, COLNO=3" is not allowed.  SQLSTATE=23502

Example: [Requête correcte]

db2 insert into shopper.sales(id,itemname,qty,price) 
values(1,'raagi',12, 120.00)  

db2 insert into shopper.sales(id,itemname,qty,price) 
values(1,'raagi',12, 120.00)

Output:

DB20000I The SQL command completed successfully.

Contraintes uniques

En utilisant ces contraintes, vous pouvez définir les valeurs des colonnes de manière unique. Pour cela, les contraintes uniques sont déclarées avec une contrainte «non nulle» au moment de la création de la table.

Syntax:

db2 create table <tab_name>(<col> <col_type> not null unique, ...)

Example:

db2 create table shopper.sales1(id bigint not null unique, 
itemname varchar(40) not null, qty int not null,price 
double not null)

Insertion des valeurs dans le tableau

Example: Pour insérer quatre lignes différentes avec des identifiants uniques comme 1, 2, 3 et 4.

db2 insert into shopper.sales1(id, itemname, qty, price) 
values(1, 'sweet', 100, 89)  

db2 insert into shopper.sales1(id, itemname, qty, price) 
values(2, 'choco', 50, 60)  

db2 insert into shopper.sales1(id, itemname, qty, price) 
values(3, 'butter', 30, 40)  

db2 insert into shopper.sales1(id, itemname, qty, price) 
values(4, 'milk', 1000, 12)

Example: Pour insérer une nouvelle ligne avec la valeur «id» 3

db2 insert into shopper.sales1(id, itemname, qty, price) 
values(3, 'cheese', 60, 80)

Output: lorsque vous essayez d'insérer une nouvelle ligne avec une valeur d'identification existante, le résultat s'affiche:

DB21034E  The command was processed as an SQL statement 
because it was not a 

valid Command Line Processor command.  During 
SQL processing it returned: 

SQL0803N  One or more values in the INSERT statement, 
UPDATE statement, or foreign key update caused by a
DELETE statement are not valid because the primary key, 
unique constraint or unique index identified by "1" constrains 
table "SHOPPER.SALES1" from having duplicate values for the 
index key. SQLSTATE=23505

Clé primaire

Comme pour les contraintes uniques, vous pouvez utiliser une contrainte «clé primaire» et «clé étrangère» pour déclarer des relations entre plusieurs tables.

Syntax:

db2 create table <tab_name>( 
      
       ,.., primary key ()) 
      

Example: Pour créer une table "salesboys" avec "sid" comme clé primaire

db2 create table shopper.salesboys(sid int not null, name 
varchar(40) not null, salary double not null, constraint 
pk_boy_id primary key (sid))

Clé étrangère

Une clé étrangère est un ensemble de colonnes dans une table qui doivent correspondre à au moins une clé primaire d'une ligne dans une autre table. C'est une contrainte référentielle ou une contrainte d'intégrité référentielle. Il s'agit d'une règle logique concernant les valeurs de plusieurs colonnes dans une ou plusieurs tables. Il permet la relation requise entre les tables.

Auparavant, vous avez créé une table nommée «shopper.salesboys». Pour cette table, la clé primaire est «sid». Vous créez maintenant une nouvelle table qui contient les détails personnels des vendeurs avec un schéma différent nommé «employé» et une table nommée «vendeurs». Dans ce cas, «sid» est la clé étrangère.

Syntax:

db2 create table <tab_name>(<col> <col_type>,constraint 
<const_name> foreign key (<col_name>)  
                  reference <ref_table> (<ref_col>)

Example: [Pour créer une table nommée 'salesboys' avec la colonne de clé étrangère 'sid']

db2 create table employee.salesboys( 
            sid int,  
            name varchar(30) not null,  
            phone int not null,  
            constraint fk_boy_id  
            foreign key (sid)  
            references shopper.salesboys (sid) 
			 on delete restrict 
                       )

Example: [Insertion de valeurs dans la table de clé primaire "shopper.salesboys"]

db2 insert into shopper.salesboys values(100,'raju',20000.00), 
(101,'kiran',15000.00), 
(102,'radha',10000.00), 
(103,'wali',20000.00), 
(104,'rayan',15000.00)

Example: [Insertion de valeurs dans la table de clé étrangère "employee.salesboys" [sans erreur]]

db2 insert into employee.salesboys values(100,'raju',98998976), 
(101,'kiran',98911176), 
(102,'radha',943245176), 
(103,'wali',89857330),  
(104,'rayan',89851130)

Si vous avez entré un nombre inconnu, qui n'est pas stocké dans la table «shopper.salesboys», il vous montrera une erreur SQL.

Example: [exécution d'erreur]

db2 insert into employee.salesboys values(105,'rayan',89851130)

Output:

DB21034E  The command was processed as an SQL statement because it 
was not a valid Command Line Processor command.  During SQL 
processing it returned: SQL0530N  The insert or update value of 
the FOREIGN KEY "EMPLOYEE.SALESBOYS.FK_BOY_ID" is not equal to any 
value of the parent key of the parent table.  SQLSTATE=23503

Vérification de la contrainte

Vous devez utiliser cette contrainte pour ajouter des restrictions conditionnelles pour une colonne spécifique dans une table.

Syntax:

db2 create table 
      
        (
        
        
          primary key (
         
          ), constraint 
          
            check (condition or condition) ) 
          
         
        
       
      

Example: [To create emp1 table with constraints values]

db2 create table empl                                                     
 (id           smallint not null,                                         
  name         varchar(9),                                                
  dept         smallint check (dept between 10 and 100), 
  job          char(5)  check (job in ('sales', 'mgr', 'clerk')), 
  hiredate     date,                                                      
  salary       decimal(7,2),                                              
  comm         decimal(7,2),                                              
  primary key (id),                                                       
  constraint yearsal check (year(hiredate) > 1986 or salary > 40500)  
 )
 

Inserting values

You can insert values into a table as shown below:

db2 insert into empl values (1,'lee', 15, 'mgr', '1985-01-01' , 
40000.00, 1000.00) 

Dropping the constraint

Let us see the syntaxes for dropping various constraints.

Dropping UNIQUE constraint

Syntax:

db2 alter table <tab_name> drop unique <const_name>

Dropping primary key

Syntax:

db2 alter table <tab_name> drop primary key 

Dropping check constraint

Syntax:

db2 alter table <tab_name> drop check <check_const_name>  

Dropping foreign key

Syntax:

db2 alter table <tab_name> drop foreigh key <foreign_key_name>  

DB2 Indexes

This chapter covers introduction to indexes, their types, creation and dropping.

Introduction

Index is a set of pointers, which can refer to rows in a table, blocks in MDC or ITC tables, XML data in an XML storage object that are logically ordered by the values of one or more keys. It is created on DB2 table columns to speed up the data access for the queries, and to cluster and partition the data efficiently. It can also improve the performance of operation on the view. A table with a unique index can have rows with unique keys. Depending on the table requirements, you can take different types of indexes.

Types of indexes

  • Unique and Non-Unique indexes
  • Clustered and non-clustered indexes

Creating indexes

For creating unique indexes, you use following syntax:

Syntax:

db2 create unique index <index_name> on 
&lttable_name>(<unique_column>) include (<column_names..>) 

Example: To create index for “shopper.sales1” table.

db2 create unique index sales1_indx on 
shopper.sales1(id) include (itemname) 

Dropping indexes

For dropping the index, you use the following syntax:

Syntax:

db2 create unique index <index_name> on 
&lttable_name>(<unique_column>) include (<column_names..>) 

Example:

db2 drop index sales_index 

DB2 Triggers

This chapter describes triggers, their types, creation and dropping of the triggers.

Introduction

A trigger is a set of actions, which are performed for responding to an INSERT, UPDATE or DELETE operation on a specified table in the database. Triggers are stored in the database at once. They handle governance of data. They can be accessed and shared among multiple applications. The advantage of using triggers is, if any change needs to be done in the application, it is done at the trigger; instead of changing each application that is accessing the trigger. Triggers are easy to maintain and they enforce faster application development. Triggers are defined using an SQL statement “CREATE TRIGGER”.

Types of triggers

There are two types of triggers:

1. BEFORE triggers

They are executed before any SQL operation.

2. AFTER triggers

They are executed after any SQL operation.

Creating a BEFORE trigger

Let us see how to create a sequence of trigger:

Syntax:

db2 create sequence <seq_name> 

Example: Creating a sequence of triggers for table shopper.sales1

db2 create sequence sales1_seq as int start with 1 increment by 1 

Syntax:

db2 create trigger <trigger_name> no cascade before insert on 
<table_name> referencing new as <table_object> for each row set 
<table_object>.<col_name>=nextval for <sequence_name> 

Example: Creating trigger for shopper.sales1 table to insert primary key numbers automatically

db2 create trigger sales1_trigger no cascade before insert on 
shopper.sales1 referencing new as obj for each row set 
obj.id=nextval for sales1_seq

Now try inserting any values:

db2 insert into shopper.sales1(itemname, qty, price) 
values('bicks', 100, 24.00) 

Retrieving values from table

Let us see how to retrieve values from a table:

Syntax:

db2 select * from <tablename>

Example:

db2 select * from shopper.sales1

Output:

  ID       ITEMNAME       QTY 
-------  ------------   ---------- 
    3      bicks            100 
    2      bread            100 
  
  2 record(s) selected. 

Creating an AFTER trigger

Let us see how to create an after trigger:

Syntax:

db2 create trigger <trigger_name> no cascade before insert on 
<table_name> referencing new as <table_object> for each row set
 <table_object>.<col_name>=nextval for <sequence_name> 

Example: [To insert and retrieve the values]

db2 create trigger sales1_tri_after after insert on shopper.sales1 
for each row mode db2sql begin atomic update shopper.sales1 
set price=qty*price; end  

Output:

//inseting values in shopper.sales1 
db2 insert into shopper.sales1(itemname,qty,price) 
values('chiken',100,124.00) 
//output 
ID    ITEMNAME       QTY         PRICE 
----- -------------- ----------- -----------                      
    3 bicks          100         2400.00 
    4 chiken         100         12400.00 
    2 bread          100         2400.00 

	3 record(s) selected. 

Dropping a trigger

Here is how a database trigger is dropped:

Syntax:

db2 drop trigger <trigger_name>  

Example:

db2 drop trigger slaes1_trigger   

DB2 - Sequences

This chapter introduces you to the concept of sequence, creation of sequence, viewing the sequence, and dropping them.

Introduction

A sequence is a software function that generates integer numbers in either ascending or descending order, within a definite range, to generate primary key and coordinate other keys among the table. You use sequence for availing integer numbers say, for employee_id or transaction_id. A sequence can support SMALLINT, BIGINT, INTEGER, and DECIMAL data types. A sequence can be shared among multiple applications. A sequence is incremented or decremented irrespective of transactions.

A sequence is created by CREATE SEQUENCE statement.

Types of Sequences

There are two type of sequences available:

  • NEXTVAL: It returns an incremented value for a sequence number.

  • PREVIOUS VALUE: It returns recently generated value.

Parameters of sequences

The following parameters are used for sequences:

Data type: This is the data type of the returned incremented value. (SMALLINT, BIGINT, INTEGER, NUMBER, DOUBLE)

START WITH: The reference value, with which the sequence starts.

MINVALUE: A minimum value for a sequence to start with.

MAXVALUE: A maximum value for a sequence.

INCREMENT BY: step value by which a sequence is incremented.

Sequence cycling: the CYCLE clause causes generation of the sequence repeatedly. The sequence generation is conducted by referring the returned value, which is stored into the database by previous sequence generation.

Creating a sequence

You can create sequence using the following syntax:

Syntax:

db2 create sequence <seq_name> 

Example: [To create a new sequence with the name ‘sales1_seq’ and increasing values from 1]

db2 create sequence sales1_seq as int start 
with 1 increment by 1  

Viewing the sequences

You can view a sequence using the syntax given below:

Syntax:

db2 value <previous/next> value for <seq_name>

Example: [To see list of previous updated value in sequence ‘sales1_seq’]

db2 values previous value for sales1_seq  

Output:

 1 
----------- 
  4 
  1 record(s) selected. 

Dropping the sequence

To remove the sequence, you need to use the “DROP SEQUENCE ” command. Here is how you do it:

Syntax:

db2 drop sequence <seq_name>>

Example: [To drop sequence ‘sales1_seq’ from database]

db2 drop sequence sales1_seq  

Output:

 DB20000I The SQL command completed successfully. 

DB2 Views

This chapter describes introduction of views, creating, modifying and dropping the views.

Introduction

A view is an alternative way of representing the data stored in the tables. It is not an actual table and it does not have any permanent storage. View provides a way of looking at the data in one or more tables. It is a named specification of a result table.

Creating a view

You can create a view using the following syntax:

Syntax:

db2 create view <view_name> (<col_name>,
<col_name1...) as select <cols>.. 
from <table_name> 

Example: Creating view for shopper.sales1 table

db2 create view view_sales1(id, itemname, qty, price) 
as select id, itemname, qty, price from 
shopper.sales1  

Modifying a view

You can modify a view using the following syntax:

Syntax:

db2 alter view <view_name> alter <col_name> 
add scope <table_or_view_name> 

Example: [To add new table column to existing view ‘view_sales1’]

db2 alter view view_sales1 alter id add 
scope shopper.sales1  

Dropping the view

You can drop a view using the following syntax:

Syntax:

db2 drop view <view_name> 

Example:

db2 drop view sales1_view  

DB2 with XML

This chapter describes use of XML with DB2.

Introduction

PureXML feature allows you to store well-formed XML documents in columns of database tables. Those columns have XML database. Data is kept in its native hierarchical form by storing XML data in XML column. The stored XML data can be accessed and managed by DB2 database server functionality. The storage of XML data in its native hierarchical form enables efficient search, retrieval, and update of XML. To update a value in XML data, you need to use XQuery, SQL or combination of both.

Creating a database and table for storing XML data

Create a database by issuing the following syntax:

Syntax:

db2 create database xmldb 

By default, databases use UTF-8 (UNICODE) code set. Activate the database and connect to it:

Syntax:

db2 activate db <db_name>
db2 connect to <db_name> 

Example:

db2 activate db xmldb 
db2 connect to xmldb  

Create a well-formed XML file and create a table with data type of the column as ‘XML’. It is mandatory to pass the SQL query containing XML syntax within double quotation marks.

Syntax:

db2 “create table <schema>.<table>(col <datatype>, 
col <xml datatype>)” 

Example:

db2 "create table shope.books(id bigint not null 
primary key, book XML)"   

Insert xml values into table, well-formed XML documents are inserted into XML type column using SQL statement ‘INSERT’.

Syntax:

db2 “insert into <table_name> values(value1, value2)” 

Example:

db2 "insert into shope.books values(1000, '<catalog>  
<book> 

<author> Gambardella Matthew</author> 
<title>XML Developers Guide</title> 
<genre>Computer</genre> 
<price>44.95</price> 
<publish_date>2000-10-01</publish_date> 
<description>An in-depth look at creating application 
with XML</description> 
</book> 

</catalog>')"   

Updating XML data in a table

You can update XML data in a table by using the following syntax:

Syntax:

db2 “update <table_name> set <column>=<value> where 
<column>=<value>”  

Example:

db2 "update shope.books set book='<catalog>  

<book> 
<author> Gambardella, Matthew</author>  
<title>XML Developers Guide</title>  
<genre>Computer</genre>  
<price>44.95</price>  
<publish_date>2000-10-01</publish_date>  
<description>An in-depth XML</description>
  
</book> 
 
</catalog>' where id=1000"  

DB2 - Backup and Recovery

This chapter describes backup and restore methods of database.

Introduction

Backup and recovery methods are designed to keep our information safe. In Command Line Interface (CLI) or Graphical User Interface (GUI) using backup and recovery utilities you can take backup or restore the data of databases in DB2 UDB.

Logging

Log files consist of error logs, which are used to recover from application errors. The logs keep the record of changes in the database. There are two types of logging as described below:

Circular logging

It is a method where the old transaction logs are overwritten when there is a need to allocate a new transaction log file, thus erasing the sequences of log files and reusing them. You are permitted to take only full back-up in offline mode. i.e., the database must be offline to take the full backup.

Archive logging

This mode supports for Online Backup and database recovery using log files called roll forward recovery. The mode of backup can be changed from circular to archive by setting logretain or userexit to ON. For archive logging, backup setting database require a directory that is writable for DB2 process.

Backup

Using Backup command you can take copy of entire database. This backup copy includes database system files, data files, log files, control information and so on.

You can take backup while working offline as well as online.

Offline backup

Syntax: [To list the active applications/databases]

db2 list application  

Output:

Auth Id  Application    Appl.      Application Id                                                
DB       # of   
         Name           Handle              
Name    Agents  
-------- -------------- ---------- ---------------------
----------------------------------------- -------- -----  
DB2INST1 db2bp          39         
*LOCAL.db2inst1.140722043938                                   
ONE      1  

Syntax: [To force application using app. Handled id]

db2 "force application (39)"   

Output:

DB20000I  The FORCE APPLICATION command completed 
successfully.  

DB21024I  This command is asynchronous and may not 
be effective immediately. 

Syntax: [To terminate Database Connection]

db2 terminate  

Syntax: [To deactivate Database]

db2 deactivate database one   

Syntax: [To take the backup file]

db2 backup database <db_name> to <location>   

Example:

db2 backup database one to /home/db2inst1/ 

Output:

Backup successful. The timestamp for this backup image is : 
20140722105345  

Online backup

To start, you need to change the mode from Circular logging to Archive Logging.

Syntax: [To check if the database is using circular or archive logging]

db2 get db cfg for one | grep LOGARCH   

Output:

First log archive method (LOGARCHMETH1) = OFF  
 Archive compression for logarchmeth1  (LOGARCHCOMPR1) = OFF 
 Options for logarchmeth1              (LOGARCHOPT1) =   
 Second log archive method             (LOGARCHMETH2) = OFF  
 Archive compression for logarchmeth2  (LOGARCHCOMPR2) = OFF  
 Options for logarchmeth2              (LOGARCHOPT2) =   

In the above output, the highlighted values are [logarchmeth1 and logarchmeth2] in off mode, which implies that the current database in “CIRCULLAR LOGGING” mode. If you need to work with ‘ARCHIVE LOGGING’ mode, you need to change or add path in the variables logarchmeth1 and logarchmeth2 present in the configuration file.

Updating logarchmeth1 with required archive directory

Syntax: [To make directories]

mkdir backup 
mkdir backup/ArchiveDest    

Syntax: [To provide user permissions for folder]

chown db2inst1:db2iadm1 backup/ArchiveDest 

Syntax: [To update configuration LOGARCHMETH1]

db2 update database configuration for one using LOGARCHMETH1 
'DISK:/home/db2inst1/backup/ArchiveDest'

You can take offline backup for safety, activate the database and connect to it.

Syntax: [To take online backup]

db2 backup database one online to 
/home/db2inst1/onlinebackup/ compress include logs   

Output:

db2 backup database one online to 
/home/db2inst1/onlinebackup/ compress include logs    

Verify Backup file using following command:

Syntax:

db2ckbkp <location/backup file>   

Example:

db2ckbkp 
/home/db2inst1/ONE.0.db2inst1.DBPART000.20140722112743.001 

Listing the history of backup files

Syntax:

db2 list history backup all for one    

Output:

                    List History File for one 
  
Number of matching file entries = 4 
 
Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log  
Backup ID  
 -- --- ------------------ ---- --- ------------ ------------ 
 --------------
  B  D  20140722105345001   F    D  S0000000.LOG S0000000.LOG 

 ------------------------------------------------------------ 
 ----------------   
 
 Contains 4 tablespace(s): 
 00001 SYSCATSPACE  
 
 00002 USERSPACE1
 
 00003 SYSTOOLSPACE 
 
 00004 TS1 
  ------------------------------------------------------------ 
  ---------------- 
  Comment: DB2 BACKUP ONE OFFLINE  
  
 Start Time: 20140722105345  
 
   End Time: 20140722105347
   
     Status: A
 ------------------------------------------------------------ 
 ---------------- 
 EID: 3 Location: /home/db2inst1 

 
 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log  
 Backup ID
 -- --- ------------------ ---- --- ------------ ------------ 
 --------------  
  B  D  20140722112239000   N       S0000000.LOG S0000000.LOG   
 ------------------------------------------------------------ 
 ------------------------------------------------------------- 
 ------------------------------- 
 
 Comment: DB2 BACKUP ONE ONLINE  
 
 Start Time: 20140722112239 
 
   End Time: 20140722112240  
   
     Status: A 
 ------------------------------------------------------------ 
 ----------------  
  EID: 4 Location: 
SQLCA Information 
 
 sqlcaid : SQLCA     sqlcabc: 136   sqlcode: -2413   sqlerrml: 0 
 
 sqlerrmc:   
 sqlerrp : sqlubIni  
 sqlerrd : (1) 0                (2) 0                (3) 0 
 
           (4) 0                (5) 0                (6) 0  
		   
 sqlwarn : (1)      (2)      (3)      (4)        (5)       (6)  
 
           (7)      (8)      (9)      (10)       (11)  
 sqlstate: 
 
 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log  
 Backup ID
  -- --- ------------------ ---- --- ------------ ------------ 
  -------------- 
   B  D  20140722112743001   F    D  S0000000.LOG S0000000.LOG   
 
 ------------------------------------------------------------ 
 ---------------- 
 Contains 4 tablespace(s): 
 
 00001 SYSCATSPACE 
 
 00002 USERSPACE1 
 
 00003 SYSTOOLSPACE 
 
 00004 TS1
  ------------------------------------------------------------- 
  ---------------- 
  Comment: DB2 BACKUP ONE OFFLINE 
  
 Start Time: 20140722112743 
 
   End Time: 20140722112743 
   
     Status: A 
 ------------------------------------------------------------- 
  ---------------- 
 EID: 5 Location: /home/db2inst1 
 
 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log 
 Backup ID   
  ------------------------------------------------------------- 
  ----------------
  
R  D  20140722114519001   F                                
20140722112743 

 ------------------------------------------------------------ 
 ----------------  
 Contains 4 tablespace(s):  
 
 00001 SYSCATSPACE 
 
  00002 USERSPACE1 
  
 00003 SYSTOOLSPACE  
 
 00004 TS1
 ------------------------------------------------------------ 
 ----------------  
Comment: RESTORE ONE WITH RF
  
 Start Time: 20140722114519 
 
   End Time: 20140722115015  
     Status: A  
	 
 ------------------------------------------------------------ 
 ----------------  
  EID: 6 Location:  

Restoring the database from backup

To restore the database from backup file, you need to follow the given syntax:

Syntax:

db2 restore database <db_name> from <location> 
taken at <timestamp>    

Example:

db2 restore database one from /home/db2inst1/ taken at 
20140722112743  

Output:

SQL2523W  Warning!  Restoring to an existing database that is 
different from  
 
the database on the backup image, but have matching names. 
The target database  
 
will be overwritten by the backup version.  The Roll-forward 
recovery logs

associated with the target database will be deleted.  

Do you want to continue ? (y/n) y 
 
DB20000I  The RESTORE DATABASE command completed successfully.   

Roll forward all the logs located in the log directory, including latest changes just before the disk drive failure.

Syntax:

db2 rollforward db <db_name> to end of logs and stop   

Example:

db2 rollforward db one to end of logs and stop  

Output:

                                 Rollforward Status  
 Input database alias                   = one  
 Number of members have returned status = 1  
 Member ID                              = 0  
 Rollforward status                     = not pending  
 Next log file to be read               =  
 Log files processed                    = S0000000.LOG - 
 S0000001.LOG  
 Last committed transaction            = 2014-07-22- 
 06.00.33.000000 UTC  
DB20000I  The ROLLFORWARD command completed successfully. 

DB2 - Database Security

This chapter describes database security.

Introduction

DB2 database and functions can be managed by two different modes of security controls:

  1. Authentication
  2. Authorization

Authentication

Authentication is the process of confirming that a user logs in only in accordance with the rights to perform the activities he is authorized to perform. User authentication can be performed at operating system level or database level itself. By using authentication tools for biometrics such as retina and figure prints are in use to keep the database from hackers or malicious users.

The database security can be managed from outside the db2 database system. Here are some type of security authentication process:

  • Based on Operating System authentications.
  • Lightweight Directory Access Protocol (LDAP)

For DB2, the security service is a part of operating system as a separate product. For Authentication, it requires two different credentials, those are userid or username, and password.

Authorization

You can access the DB2 Database and its functionality within the DB2 database system, which is managed by the DB2 Database manager. Authorization is a process managed by the DB2 Database manager. The manager obtains information about the current authenticated user, that indicates which database operation the user can perform or access.

Here are different ways of permissions available for authorization:

Primary permission: Grants the authorization ID directly.

Secondary permission: Grants to the groups and roles if the user is a member

Public permission: Grants to all users publicly.

Context-sensitive permission: Grants to the trusted context role.

Authorization can be given to users based on the categories below:

  • System-level authorization
  • System administrator [SYSADM]
  • System Control [SYSCTRL]
  • System maintenance [SYSMAINT]
  • System monitor [SYSMON]

Authorities provide of control over instance-level functionality. Authority provide to group privileges, to control maintenance and authority operations. For instance, database and database objects.

  • Database-level authorization
  • Security Administrator [SECADM]
  • Database Administrator [DBADM]
  • Access Control [ACCESSCTRL]
  • Data access [DATAACCESS]
  • SQL administrator. [SQLADM]
  • Workload management administrator [WLMADM]
  • Explain [EXPLAIN]

Authorities provide controls within the database. Other authorities for database include with LDAD and CONNECT.

  • Object-Level Authorization: Object-Level authorization involves verifying privileges when an operation is performed on an object.
  • Content-based Authorization: User can have read and write access to individual rows and columns on a particular table using Label-based access Control [LBAC].

DB2 tables and configuration files are used to record the permissions associated with authorization names. When a user tries to access the data, the recorded permissions verify the following permissions:

  • Authorization name of the user
  • Which group belongs to the user
  • Which roles are granted directly to the user or indirectly to a group
  • Permissions acquired through a trusted context.

While working with the SQL statements, the DB2 authorization model considers the combination of the following permissions:

  • Permissions granted to the primary authorization ID associated with the SQL statements.
  • Secondary authorization IDs associated with the SQL statements.
  • Granted to PUBLIC
  • Granted to the trusted context role.

Instance level authorities

Let us discuss some instance related authorities.

System administration authority (SYSADM)

It is highest level administrative authority at the instance-level. Users with SYSADM authority can execute some databases and database manager commands within the instance. Users with SYSADM authority can perform the following operations:

  • Upgrade a Database
  • Restore a Database
  • Update Database manager configuration file.

System control authority (SYSCTRL)

It is the highest level in System control authority. It provides to perform maintenance and utility operations against the database manager instance and its databases. These operations can affect system resources, but they do not allow direct access to data in the database.

Users with SYSCTRL authority can perform the following actions:

  • Updating the database, Node, or Distributed Connect Service (DCS) directory
  • Forcing users off the system-level
  • Creating or Dropping a database-level
  • Creating, altering, or dropping a table space
  • Using any table space
  • Restoring Database

System maintenance authority (SYSMAINT)

It is a second level of system control authority. It provides to perform maintenance and utility operations against the database manager instance and its databases. These operations affect the system resources without allowing direct access to data in the database. This authority is designed for users to maintain databases within a database manager instance that contains sensitive data.

Only Users with SYSMAINT or higher level system authorities can perform the following tasks:

  • Taking backup
  • Restoring the backup
  • Roll forward recovery
  • Starting or stopping instance
  • Restoring tablespaces
  • Executing db2trc command
  • Taking system monitor snapshots in case of an Instance level user or a database level user.

A user with SYSMAINT can perform the following tasks:

  • Query the state of a tablespace
  • Updating log history files
  • Reorganizing of tables
  • Using RUNSTATS (Collection catalog statistics)

System monitor authority (SYSMON)

With this authority, the user can monitor or take snapshots of database manager instance or its database. SYSMON authority enables the user to run the following tasks:

  • GET DATABASE MANAGER MONITOR SWITCHES
  • GET MONITOR SWITCHES
  • GET SNAPSHOT
  • LIST
    • LIST ACTIVE DATABASES
    • LIST APPLICATIONS
    • LIST DATABASE PARTITION GROUPS
    • LIST DCS APPLICATIONS
    • LIST PACKAGES
    • LIST TABLES
    • LIST TABLESPACE CONTAINERS
    • LIST TABLESPACES
    • LIST UTITLITIES
  • RESET MONITOR
  • UPDATE MONITOR SWITCHES

Database authorities

Each database authority holds the authorization ID to perform some action on the database. These database authorities are different from privileges. Here is the list of some database authorities:

ACCESSCTRL: allows to grant and revoke all object privileges and database authorities.

BINDADD: Allows to create a new package in the database.

CONNECT: Allows to connect to the database.

CREATETAB: Allows to create new tables in the database.

CREATE_EXTERNAL_ROUTINE: Allows to create a procedure to be used by applications and the users of the databases.

DATAACCESS: Allows to access data stored in the database tables.

DBADM: Act as a database administrator. It gives all other database authorities except ACCESSCTRL, DATAACCESS, and SECADM.

EXPLAIN: Allows to explain query plans without requiring them to hold the privileges to access the data in the tables.

IMPLICIT_SCHEMA: Allows a user to create a schema implicitly by creating an object using a CREATE statement.

LOAD: Allows to load data into table.

QUIESCE_CONNECT: Allows to access the database while it is quiesce (temporarily disabled).

SECADM: Allows to act as a security administrator for the database.

SQLADM: Allows to monitor and tune SQL statements.

WLMADM: Allows to act as a workload administrator

Privileges

SETSESSIONUSER

Authorization ID privileges involve actions on authorization IDs. There is only one privilege, called the SETSESSIONUSER privilege. It can be granted to user or a group and it allows to session user to switch identities to any of the authorization IDs on which the privileges are granted. This privilege is granted by user SECADM authority.

Schema privileges

This privileges involve actions on schema in the database. The owner of the schema has all the permissions to manipulate the schema objects like tables, views, indexes, packages, data types, functions, triggers, procedures and aliases. A user, a group, a role, or PUBLIC can be granted any user of the following privileges:

  • CREATEIN: allows to create objects within the schema
  • ALTERIN: allows to modify objects within the schema.

DROPIN

This allows to delete the objects within the schema.

Tablespace privileges

These privileges involve actions on the tablespaces in the database. User can be granted the USE privilege for the tablespaces. The privileges then allow them to create tables within tablespaces. The privilege owner can grant the USE privilege with the command WITH GRANT OPTION on the tablespace when tablespace is created. And SECADM or ACCESSCTRL authorities have the permissions to USE privileges on the tablespace.

Table and view privileges

The user must have CONNECT authority on the database to be able to use table and view privileges. The privileges for tables and views are as given below:

CONTROL

It provides all the privileges for a table or a view including drop and grant, revoke individual table privileges to the user.

ALTER

It allows user to modify a table.

DELETE

It allows the user to delete rows from the table or view.

INDEX

It allows the user to insert a row into table or view. It can also run import utility.

REFERENCES

It allows the users to create and drop a foreign key.

SELECT

It allows the user to retrieve rows from a table or view.

UPDATE

It allows the user to change entries in a table, view.

Package privileges

User must have CONNECT authority to the database. Package is a database object that contains the information of database manager to access data in the most efficient way for a particular application.

CONTROL

It provides the user with privileges of rebinding, dropping or executing packages. A user with this privileges is granted to BIND and EXECUTE privileges.

BIND

It allows the user to bind or rebind that package.

EXECUTE

Allows to execute a package.

Index privileges

This privilege automatically receives CONTROL privilege on the index.

Sequence privileges

Sequence automatically receives the USAGE and ALTER privileges on the sequence.

Routine privileges

It involves the action of routines such as functions, procedures, and methods within a database.

DB2 - Roles

Introduction

A role is a database object that groups multiple privileges that can be assigned to users, groups, PUBLIC or other roles by using GRANT statement.

Restrictions on roles

  • A role cannot own database objects.
  • Permissions and roles granted to groups are not considered when you create the following database objects.
    • Package Containing static SQL
    • Views
    • Materialized Query Tables (MQT)
    • Triggers
    • SQL Routines

Creating and granting membership in roles

Syntax: [To create a new role]

db2 create role <role_name> 

Example: [To create a new role named ‘sales’ to add some table to be managed by some user or group]

db2 create role sales 

Output:

DB20000I The SQL command completed successfully. 

Granting role from DBADM to a particular table

Syntax: [To grant permission of a role to a table]

db2 grant select on table <table_name> to role <role_name> 

Example: [To add permission to manage a table ‘shope.books’ to role ‘sales’]

db2 grant select on table shope.books to role sales 

Output:

DB20000I  The SQL command completed successfully. 

Security administrator grants role to the required users. (Before you use this command, you need to create the users.)

Syntax: [To add users to a role]

db2 grant role <role_name> to user <username> 

Example: [To add a user ‘mastanvali’ to a role ‘sales’]

db2 grant sales to user mastanvali  

Output:

DB20000I  The SQL command completed successfully. 

Role hierarchies

For creating a hierarchies for roles, each role is granted permissions/ membership with another role.

Syntax: [before this syntax create a new role with name of “production”]

db2 grant role <roll_name> to role <role_name>

Example: [To provide permission of a role ‘sales’ to another role ‘production’]

db2 grant sales to role production 

DB2 - LDAP

Introduction

LDAP is Lightweight Directory Access Protocol. LDAP is a global directory service, industry-standard protocol, which is based on client-server model and runs on a layer above the TCP/IP stack. The LDAP provides a facility to connect to, access, modify, and search the internet directory.

The LDAP servers contain information which is organized in the form of a directory tree. The clients ask server to provide information or to perform some operation on a particular information. The server answers the client by providing required information if it has one, or it refers the client to another server for action on required information. The client then acquires the desired information from another server.

The tree structure of directory is maintained same across all the participating servers. This is a prominent feature of LDAP directory service. Hence, irrespective of which server is referred to by the client, the client always gets required information in an error-free manner. Here, we use LDAP to authenticate IBM DB2 as a replacement of operating system authentication.

There are two types of LDAP:

  1. Transparent
  2. Plug-in

Let us see how to configure a transparent LDAP.

Configuring transparent LDAP

To start with configuration of transparent LDAP, you need to configure the LDAP server.

LDAP server configuration

Create a SLAPD.conf file, which contains all the information about users and group object in the LDAP. When you install LDAP server, by default it is configured with basic LDAP directory tree on your machine.

The table shown below indicates the file configuration after modification.

The text highlighted with yellow the code box means for the following:

DBA user-id = “db2my1”, group = “db1my1adm”, password= “db2my1” Admin user-id = “my1adm”, group = “dbmy1ctl”.

# base dn: example.com 
dn: dc=example,dc=com 
dc: example 
o: example 
objectClass: organization 
objectClass: dcObject 
# pc box db 
dn: dc=db697,dc=example,dc=com 
dc: db697 
o: db697 
objectClass: organization 
objectClass: dcObject 
# 
# Group: db
      
       adm 
# 
dn: cn=dbmy1adm,dc=db697,dc=example,dc=com 
cn: dbmy1adm 
objectClass: top 
objectClass: posixGroup 
gidNumber: 400 
objectClass: groupOfNames 
member: uid=db2my1,cn=dbmy1adm,dc=db697,dc=example,dc=com 
memberUid: db2my1 
# 
# User: db2
       
         # dn: uid=db2my1,cn=dbmy1adm,dc=db697,dc=example,dc=com cn: db2my1 sn: db2my1 uid: db2my1 objectClass: top objectClass: inetOrgPerson objectClass: posixAccount uidNumber: 400 gidNumber: 400 loginShell: /bin/csh homeDirectory: /db2/db2my1 # # Group: db
        
         ctl # dn: cn=dbmy1ctl,dc=db697,dc=example,dc=com cn: dbmy1ctl objectClass: top objectClass: posixGroup gidNumber: 404 objectClass: groupOfNames member: uid=my1adm,cn=dbmy1adm,dc=db697,dc=example,dc=com memberUid: my1adm # # User: 
         
          adm # dn: uid=my1adm,cn=dbmy1ctl,dc=db697,dc=example,dc=com cn: my1adm sn: my1adm uid: my1adm objectClass: top objectClass: inetOrgPerson objectClass: posixAccount uidNumber: 404 gidNumber: 404 loginShell: /bin/csh homeDirectory: /home/my1adm 
         
        
       
      

Save the above file with name ‘/var/lib/slapd.conf’, then execute this file by following command to add these values into LDAP Server. This is a linux command; not a db2 command.

ldapadd r- -D ‘cn=Manager,dc=example,dc=com” –W –f 
/var/lib/slapd.conf 

After registering the DB2 users and the DB2 group at the LDAP Server, logon to the particular user where you have installed instance and database. You need to configure LDAP client to confirm to client where your server is located, be it remote or local.

LDAP client configuration

The LDAP Client configuration is saved in the file ‘ldap.conf’. There are two files available for configuration parameters, one is common and the other is specific. You should find the first one at ‘/etc/ldap.conf’ and the latter is located at ‘/etc/openldap/ldap.conf’.

The following data is available in common LDAP client configuration file

# File: /etc/ldap.conf  
# The file contains lots of more entries and many of them  
# are comments. You show only the interesting values for now  
host localhost  
base dc=example,dc=com  
ldap_version 3  
pam_password crypt  
pam_filter objectclass=posixAccount  
nss_map_attribute uniqueMember member 
nss_base_passwd dc=example,dc=com  
nss_base_shadow dc=example,dc=com  
nss_base_group dc=example,dc=com 

You need to change the location of server and domain information according to the DB2 configuration. If we are using server in same system then mention it as ‘localhost’ at ‘host’ and at ‘base’ you can configure which is mentioned in ‘SLAPD.conf’ file for LDAP server.

Pluggable Authentication Model (PAM) is an API for authentication services. This is common interface for LDAP authentication with an encrypted password and special LDAP object of type posixAccount. All LDAP objects of this type represent an abstraction of an account with portable Operating System Interface (POSIX) attributes.

Network Security Services (NSS) is a set of libraries to support cross-platform development of security-enabled client and server applications. This includes libraries like SSL, TLS, PKCS S/MIME and other security standards.

You need to specify the base DN for this interface and two additional mapping attributes. OpenLDAP client configuration file contains the entries given below:

host localhost  
base dc=example,dc=com

Till this you just define the host of LDAP serve and the base DN.

Validating OpenLDAP environment

After you configured your LDAP Server and LDAP Client, verify both for communication.

Step1: Check your Local LDAP server is running. Using below command:

ps -ef | grep -i ldap

This command should list the LDAP deamon which represents your LDAP server:

/usr/lib/openldap/slapd -h ldap:/// -u ldap -g ldap -o slp=on

This indicates that you LDAP server is running and is waiting for request from clients. If there is no such process for previous commands you can start LDAP server with the ’rcldap’ command.

rcldap start 

When the server starts, you can monitor this in the file ‘/var/log/messages/ by issuing the following command.

tail –f /var/log/messages 

Testing connection to LDAP server with ldapsearch

The ldapsearch command opens a connection to an LDAP server, binds to it and performs a search query which can be specified by using special parameters ‘-x’ connect to your LDAP server with a simple authentication mechanism by using the –x parameter instead of a more complex mechanism like Simple Authentication and Security Layer (SASL)

ldapsearch –x  

LDAP server should reply with a response given below, containing all of your LDAP entries in a LDAP Data Interchange Format(LDIF).

# extended LDIF  
#  
# LDAPv3  
# base <> with scope subtree  
# filter: (objectclass=*) 
# requesting: ALL  
# example.com  
dn: dc=example,
dc=com  dc: example  
o: example  
objectClass: organization  
objectClass: dcObject  
# search result  
search: 2  
result: 0 Success  
# numResponses: 2  
# numEntries: 1  

Configuring DB2

After working with LDAP server and client, you need to configure our DB2 database for use with LDAP. Let us discuss, how you can install and configure your database to use our LDAP environment for the DB2 user authentication process.

Configuring DB2 and LDAP interaction plug-ins

IBM provides a free package with LDAP plug-ins for DB2. The DB2 package includes three DB2 security plug-ins for each of the following:

  • server side authentication
  • client side authentication
  • group lookup

Depending upon your requirements, you can use any of the three plug-ins or all of them. This plugin do not support environments where some users are defined in LDAP and others in the operating Systems. If you decide to use the LDAP plug-ins, you need to define all users associated with the database in the LDAP server. The same principle applies to the group plug-in.

You have to decide which plug-ins are mandatory for our system. The client authentication plug-ins used in scenarios where the user ID and the password validation supplied on a CONNECT or ATTACH statement occurs on the client system. So the database manager configuration parameters SRVCON_AUTH or AUTHENTICATION need to be set to the value CLIENT. The client authentication is difficult to secure and is not generally recommended. Server plug-in is generally recommended because it performs a server side validation of user IDs and passwords, if the client executes a CONNECT or ATTACH statement and this is secure way. The server plug-in also provides a way to map LDAP user IDs DB2 authorization IDs.

Now you can start installation and configuration of the DB2 security plug-ins, you need to think about the required directory information tree for DB2. DB2 uses indirect authorization which means that a user belongs to a group and this group was granted with fewer authorities. You need to define all DB2 users and DB2 groups in LDAP directory.

Image

The LDIF file openldap.ldif should contain the code below:

#  
# LDAP root object  
# example.com  
#  
dn: dc=example,
dc=com  
dc: example  
o: example  
objectClass: organization  
objectClass: dcObject 
 #  
 # db2 groups  
 #  
 dn: cn=dasadm1,dc=example,dc=com  
 cn: dasadm1  
 objectClass: top  
 objectClass: posixGroup  
 gidNumber: 300  
 objectClass: groupOfNames 
 member: uid=dasusr1,cn=dasadm1,dc=example,dc=com  
 memberUid: dasusr1  
 dn: cn=db2grp1,dc=example,dc=com  
 cn: db2grp1  
 objectClass: top  
 objectClass: posixGroup  
 gidNumber: 301  
 objectClass: groupOfNames  
 member: uid=db2inst2,cn=db2grp1,dc=example,dc=com  memberUid: db2inst2  
 dn: cn=db2fgrp1,dc=example,dc=com  
 cn: db2fgrp1  
 objectClass: top 
 objectClass: posixGroup  
 gidNumber: 302  
 objectClass: groupOfNames 
 member: uid=db2fenc1,cn=db2fgrp1,dc=example,dc=com  
 memberUid: db2fenc1  
 #  
 # db2 users  
 #  
 dn: uid=dasusr1,
 cn=dasadm1,
 dc=example,dc=com  
 cn: dasusr1  
 sn: dasusr1  
 uid: dasusr1  
 objectClass: top  
 objectClass: inetOrgPerson 
 objectClass: posixAccount 
 uidNumber: 300  
 gidNumber: 300  
 loginShell: /bin/bash 
 homeDirectory: /home/dasusr1  
 dn: uid=db2inst2,cn=db2grp1,dc=example,dc=com  
 cn: db2inst2  
 sn: db2inst2  
 uid: db2inst2  
 objectClass: top  
 objectClass: inetOrgPerson  
 objectClass: posixAccount  
 uidNumber: 301  
 gidNumber: 301  
 loginShell: /bin/bash  
 homeDirectory: /home/db2inst2  
 dn: uid=db2fenc1,cn=db2fgrp1,dc=example,dc=com  
 cn: db2fenc1  
 sn: db2fenc1  
 uid: db2fenc1  
 objectClass: top  
 objectClass: inetOrgPerson  
 objectClass: posixAccount  
 uidNumber: 303  
 gidNumber: 303  
 loginShell: /bin/bash  
 homeDirectory: /home/db2fenc1 
 

Create a file named ‘db2.ldif’ and paste the above example into it. Using this file, add the defined structures to your LDAP directory.

To add the DB2 users and DB2 groups to the LDAP directory, you need to bind the user as ‘rootdn’ to the LDAP server in order to get the exact privileges.

Execute the following syntaxes to fill the LDAP information directory with all our objects defined in the LDIF file ‘db2.ldif’

ldapadd –x –D “cn=Manager, dc=example,dc=com” –W –f <path>/db2.ldif 

Perform the search result with more parameter

ldapsearch –x |more 

Preparing file system for DB2 usage

Creating instance for our LDAP user db2inst2. This user requires home directory with two empty files inside the home directory. Before you create a new instance, you need to create a user who will be the owner of the instance.

After creating the instance user, you should have to create the file ‘.profile’ and ‘.login’ in user home directory, which will be modified by DB2. To create this file in the directory, execute the following command:

mkdir /home/db2inst2  
mkdir /home/db2inst2/.login 
mkdir /home/db2inst2/.profile  

You have registered all users and groups related with DB2 in LDAP directory, now you can create an instance with the name ‘db2inst2’ with the instance owner id ‘db2inst2’ and use the fenced user id ‘db2fenc1’, which is needed for running user defined functions (UDFs)or stored procedures.

/opt/ibm/db2/V10.1/instance/db2icrt –u db2fenc1 db2inst2  
DBI1070I Program db2icrt completed successfully.  

Now check the instance home directory. You can see new sub-directory called ‘sqllib’ and the .profile and .login files customized for DB2 usage.

Configuring authentication public-ins for LDAP support in DB2

Copy the required LDAP plug-ins to the appropriate DB2 directory:

cp            /
      
       /
       
        /v10/IBMLDAPauthserver.so /home/db2inst2/sqllib/security
        
         /plugin/server/. cp /
         
          /
          
           /v10/IBMLDAPgroups.so /home/db2inst2/sqllib/security
           
            /plugin/group/. 
           
          
         
        
       
      

Once the plug-ins are copied to the specified directory, you toned to login to DB2 instance owner and change the database manager configuration to use these plug-ins.

Su – db2inst2  
db2inst2> db2 update dbm cfg using svrcon_pw_plugin 
IBMLDAPauthserver 
db2inst2> db2 update dbm cfg using group_plugin 
IBMLDAPgroups 
db2inst2> db2 update dbm cfg using authentication 
SERVER_ENCRYPT 
db2inst2> db2stop 
db2inst2> db2start  

This modification comes into effect after you start DB2 instance. After restarting the instance, you need to install and configure the main DB2 LDAP configuration file named “IBMLDAPSecurity.ini” to make DB2 plug-ins work with the current LDAP configuration.

IBMLDAPSecurity.ini file contains

;-----------------------------------------------------------  
; SERVER RELATED VALUES  
;-----------------------------------------------------------  
; Name of your LDAP server(s).  
; This is a space separated list of LDAP server addresses,  
; with an optional port number for each one:  
; host1[:port] [host2:[port2] ... ]  
; The default port number is 389, or 636 if SSL is enabled.  
LDAP_HOST = my.ldap.server  
;-----------------------------------------------------------  
; USER RELATED VALUES  
;-----------------------------------------------------------  
rs  
; LDAP object class used for use USER_OBJECTCLASS = posixAccount  
; LDAP user attribute that represents the "userid"  
; This attribute is combined with the USER_OBJECTCLASS and  
; USER_BASEDN (if specified) to construct an LDAP search  
; filter when a user issues a DB2 CONNECT statement with an  
; unqualified userid. For example, using the default values 
; in this configuration file, (db2 connect to MYDB user bob  
; using bobpass) results in the following search filter:  
OrgPerson)(uid=bob)  
; &(objectClass=inet USERID_ATTRIBUTE = uid  
representing the DB2 authorization ID  
; LDAP user attribute, AUTHID_ATTRIBUTE = uid  
;-----------------------------------------------------------  
; GROUP RELATED VALUES  
;-----------------------------------------------------------  
ps  
; LDAP object class used for grou GROUP_OBJECTCLASS = groupOfNames  
at represents the name of the group  
; LDAP group attribute th GROUPNAME_ATTRIBUTE = cn  
; Determines the method used to find the group memberships  
; for a user. Possible values are:  
; SEARCH_BY_DN - Search for groups that list the user as  
; a member. Membership is indicated by the  
; group attribute defined as  
; GROUP_LOOKUP_ATTRIBUTE. 
; USER_ATTRIBUTE - A user's groups are listed as attributes  
; of the user object itself. Search for the  
; user attribute defined as  
TRIBUTE to get the groups.  
; GROUP_LOOKUP_AT GROUP_LOOKUP_METHOD = SEARCH_BY_DN  
; GROUP_LOOKUP_ATTRIBUTE  
; Name of the attribute used to determine group membership,  
; as described above.  
llGroups  
; GROUP_LOOKUP_ATTRIBUTE = ibm-a GROUP_LOOKUP_ATTRIBUTE = member 

Now locate the file IBMLDAPSecurity.ini file in the current instance directory. Copy the above sample contents into the same.

Cp 
/
      
       /db2_ldap_pkg/IBMLDAPSecurity.ini  
/home/db2inst2/sqllib/cfg/ 

      

Now you need to restart your DB2 instance, using two syntaxes given below:

db2inst2> db2stop 

Db2inst2> db2start 

At this point, if you try ‘db2start’ command, you will get security error message. Because, DB2 security configuration is not yet correctly configured for your LDAP environment.

Customizing both configurations

Keep LDAP_HOST name handy, which is configured in slapd.conf file.

Now edit IMBLDAPSecurity.ini file and type the LDAP_HOST name. The LDAP_HOST name in both the said files must be identical.

The contents of file are as shown below:

      ;-----------------------------------------------------------  
      ; SERVER RELATED VALUES  
      ;-----------------------------------------------------------  
      LDAP_HOST = localhost  
      ;-----------------------------------------------------------  
      ; USER RELATED VALUES  
      ----------------------------  
      ;-------------------------------  
      USER_OBJECTCLASS = posixAccount  
      USER_BASEDN = dc=example,dc=com  
      USERID_ATTRIBUTE = uid  
      AUTHID_ATTRIBUTE = uid  
      ;-----------------------------------------------------------  
      ; GROUP RELATED VALUES  
      ;-----------------------------------------------------------  
      GROUP_OBJECTCLASS = groupOfNames 
	  GROUP_BASEDN = dc=example,dc=com  
      GROUPNAME_ATTRIBUTE = cn  
      GROUP_LOOKUP_METHOD = SEARCH_BY_DN  
      GROUP_LOOKUP_ATTRIBUTE = member 

After changing these values, LDAP immediately takes effect and your DB2 environment with LDAP works perfectly.

You can logout and login again to ‘db2inst2’ user.

Now your instance is working with LDAP directory.

Next Page