- PL/SQL
-
PL/SQL (sigle de Procedural Language / Structured Query Language) est un langage procédural propriétaire créé par Oracle et utilisé dans le cadre de bases de données relationnelles. Il a été influencé par le langage Ada.
Il permet de combiner des requêtes SQL et des instructions procédurales (boucles, conditions...), dans le but de créer des traitements complexes destinés à être stockés sur le serveur de base de données (objets serveur), comme par exemple des procédures stockées ou des déclencheurs.
Les dernières évolutions proposées par Oracle reposent sur un moteur permettant de créer et gérer des objets contenant des méthodes et des propriétés.
PostgreSQL propose un langage procédural proche du PL/SQL, le PL/pgSQL.
Sommaire
Concepts
Blocs
Tout programme PL/SQL doit se présenter sous forme de blocs. Voici la forme générale d'un bloc.
DECLARE déclarations BEGIN implémentation EXCEPTION gestion des exceptions END;
Un bloc PL/SQL comprend d'abord une partie dédiée à la définition de toutes les variables employées dans le bloc. Elle commence par l'instruction DECLARE et est facultative. La section principale commence avec l'instruction BEGIN. Elle contient les instructions du programme. Si une variable est utilisée dans cette section alors qu'elle n'a pas été déclarée dans la section de déclaration, le compilateur générera une erreur. Enfin, la dernière section est appelée en cas d'erreur dans la section précédente. Elle commence par l'instruction EXCEPTION et on y traite l'ensemble des exceptions levées dans la section principale.
Structure du code
PL/SQL permet de grouper les instructions dans des procédures et des fonctions, ces termes ont la même signification qu'en Pascal: une fonction est un bloc de code prenant des paramètres et qui effectue des traitements pour obtenir un résultat retourné, une procédure recouvre la même notion sauf qu'une procédure ne retourne pas de résultat. Les arguments passés aux procédures et fonctions peuvent lui être donnés en lecture seule (IN), en écriture (OUT) ou en lecture-écriture (IN OUT); le développeur peut également choisir le passage par valeur (comportement normal) ou par référence (NO COPY).
Des fonctions et procédures peuvent être regroupées dans des unités nommées paquetages, elles sont alors accessibles sous le même espace de noms. D'une manière similaire aux modules de Pascal, la création d'un paquetage requiert l'écriture d'une spécification exposant le prototype des fonctions et procédures du paquetage, ainsi que des variables et types publics. En second lieu, l'implémentation du paquetage est faite séparément; elle contient le code des procédures et fonctions ainsi que la déclaration d'éléments privés.
Variables
Les premiers types de variables à disposition sont les types SQL supportés par le serveur Oracle (INTEGER, VARCHAR, ...), mais il est possible de définir des types personnalisés.
Voir aussi
Articles connexes
Liens externes
- (fr) Guide pour débuter
- (fr) Guide simplifié pour débuter
- (en) PL/SQL Tutorials
- (en) PL/SQL User's Guide and Reference
- (en) PL/SQL Tutorial
Wikimedia Foundation. 2010.