ABAP

Un article de Wikipédia, l'encyclopédie libre.

ABAP est un langage de programmation propriétaire, faisant partie de l'ensemble logiciel SAP. Il s'agit actuellement du langage utilisé dans la programmation des Web Application Server faisant partie de la plateforme Netweaver pour la réalisation de progiciels.

Sa version ABAP/4 est objet, le chiffre 4 faisant de plus référence à son appartenance à la classe des langages de quatrième génération.

Sommaire

[modifier] Histoire

L'acronyme ABAP signifiant à l'origine Allgemeiner Berichtsaufbereitungsprozessor (processeur générique pour la préparation de rapport) et a par la suite été anglicisé en Advanced Business Application Programming.

L'ABAP est l'un des successeurs du COBOL et est apparu dans les années 1980 dans la vague des langages de quatrième génération (4GLs). Il s'agit d'un dérivé du langage permettant de réaliser des sorties de données (appelées rapports) de l'application SAP R/2, sur lequel de nombreuses multinationales avaient bâti leur architecture d'application professionnelle. L'ABAP a par la suite été maintenu comme langage de référence pour les applications SAP R/3 qui sont apparus en 1992.

À l'origine, ce langage comprenait le concept de Base de données logique qui devait permettre à tout utilisateur de créer lui-même les rapports dont il avait besoin. Il s'est avéré en fait que développer des programmes avec ce langage ne pouvait être fait en pratique que par des professionnels disposant d'une solide expérience.

Le langage a été par la suite étendu pour englober un modèle de données orienté objet (ABAP Objects) à partir de sa version 4.5, pour être finalement intégré comme langage d'un produit plus général appelé NetWeaver. Ce dernier utilise aussi bien l'ABAP que le java.

C'est un langage interprété.

[modifier] Composants du langage

Le code source: il est écrit directement dans un composant de SAP appelé SAP Workbench et il sera stocké dans la base d'information de l'outil. Ce langage, de même que java, a besoin d'être compilé pour pouvoir être exécuté. Cependant, à la différence de java, avant chaque utilisation d'un programme, le processeur SAP vérifie qu'il possède la dernière version du programme. Si ce n'est pas le cas, ce dernier est recompilé à la volée.

Le dictionnaire de données (DDIC) : la base de données est masquée pour le programmeur. Il y accède donc au travers de clauses faisant partie du langage lui-même. De même, la gestion du modèle de données est réalisée au travers d'un composant qui créera ou modifiera lui-même les tables de données. Ce dictionnaire de données comprend :

  • Des domaines représentant un concept élémentaire (par exemple un fournisseur, une référence article) ; chaque élément de donnée comprend au minimum un type de donnée et la spécification de son occupation mémoire.
  • Des éléments de données . Chaque élément de donnée est construit à partir d'un domaine et correspond à une utilisation particulière de ce dernier pour stocker une information, ou pour afficher un champ. Chaque élément de donnée comprend quatre descriptions textuelles qui peuvent être traduites (de manière à rendre l'application utilisable par des locuteurs de différentes langues).
  • Des structures et des tables de différents types permettant de stocker des informations, d'utiliser des types composites pour les transferts de données entre programmes et de stocker de l'information dans la base.

Un outil de transport . À chaque modification d'un programme, celui-ci doit être transporté de l'environnement dans lequel il est créé vers un environnement de test puis dans l'environnement de production (chacun de ces environnements dispose de jeux de données distincts, il peut exister plus de trois environnements dans un système d'information donné). Cette opération est réalisée par la mise en œuvre d'un ordre de transport.

[modifier] L'ABAP pour quoi faire ?

L'ABAP jusqu'à l'apparition de NetWeaver était la brique constituante des systèmes SAP R/3. Il permet de réaliser :

  • Des rapports . L'ABAP a été conçu à l'origine pour cela et comprendre des clauses générant automatiquement des rapports. Un rapport est constitué en général d'un écran de sélection de données et d'une liste affichant le résultant. Les rapports peuvent aussi être générés par un utilisateur avec SAP Business Report ou par un utilisateur simplement averti avec SAP Query.
  • Des transactions . Une transaction est constituée d'une succession d'écrans appelées Dynpro, chaînés entre eux par un programme contenant la logique de la transaction.
  • Des fonctions . Il s'agit de sous-programmes contenant la description d'une fonctionnalité du système. Ces fonctions peuvent être internes et permettre ainsi une plus grande cohérence du système ou permettre la communication avec d'autres systèmes. Si les systèmes externes sont aussi des systèmes SAP R/3 on parlera de fonctions RFC (Remote Function Call) sinon la fonction sera généralement encapsulée et les appels pourront être réalisés à partir d'autres langages, on parlera alors de BAPI. Enfin, il existe d'autres variétés de fonctions et de protocole comme par exemple :
  • tRFC: transactional RFC qui permet de réaliser de véritables transactions entre systèmes ;
  • qRFC: queued RFC qui permet d'assurer la synchronisation d'appels en masse entre deux systèmes ; ce protocole permet ainsi d'assurer la consistance des données dans le module de datawarehouse BW.

[modifier] Liens externes

  • SAP-Integration Une communauté française d'aide à SAP et au langage ABAP contenant des tutoriaux
  • Interface PHP / SAPRFC Permet d'interfacer des applications web / PHP à SAP et d'y executer des BAPI, Modules fonctions executables à distance

[modifier] Exemples de programmes ABAP

Le grand classique:

REPORT Z_XX_TRANSACTION.
*
* -- Commentaire de ligne
*
PARAMETERS p_input(16) TYPE c DEFAULT 'Hello World!'.

*
*-- Affichage du résultat:
*
 WRITE: / 'Lentrée était: ', p_input.

Un exemple plus commun avec recherche dans la base de données:

REPORT Z_XX_TRANSACTION.
*
* -- Declaration de données
*
TABLES:
 TSTC,                                               "Tables des transactions
 TSTCT.                                              "Tables de leurs descriptions
* Tables internes pour l'exemple
DATA X_TSTC  LIKE TSTC OCCURS 10 WITH HEADER LINE.
DATA X_TSTCT LIKE TSTCT OCCURS 10 WITH HEADER LINE.
" -- Début de la déclaration de l'écran de sélection
SELECT-OPTIONS S_TCODE FOR TSTC-TCODE OBLIGATORY.
' -- Début de l'extraction des données
*
START-OF-SELECTION.
*
 REFRESH: X_TSTC, X_TSTCT.
 SELECT * FROM TSTC INTO TABLE X_TSTC
   WHERE TCODE IN S_TCODE.
 SELECT * FROM TSTCT INTO TABLE X_TSTCT
   WHERE TCODE IN S_TCODE
   AND   SPRSL = SY-LANGU.
*
TOP-OF-PAGE.
*
 "    -- Haut de page (sur chaque page)
 WRITE / 'Programme exemple: liste de transactions '.
 SKIP.                                                "Saut de ligne
 ULINE.                                               "Ligne continue
*
END-OF-PAGE.
*
 "    -- Bas de page (sur chaque page)
 ULINE.
*
END-OF-SELECTION.
*
 "    -- Liste principale
LOOP AT X_TSTC.                                        "Boucle sur les transactions
  " Recherche de la description
  READ TABLE X_TSTCT WITH KEY TCODE = X_TSTC-TCODE.
  IF SY-SUBRC NE 0. " Erreur
    WRITE : /  "Saut de ligne
     SY-VLINE,                                         "Barre verticale
     X_TSTC, SY-VLINE,                                 "Code puis barre
     (25) '-- Pas de description --'                   "Largeur du texte spécifiée
     SY-VLINE.                                         "Barre verticale
  ELSE.
    WRITE : /                                          "Saut de ligne
     SY-VLINE,                                         "Barre verticale
     X_TSTC, SY-VLINE,                                 "Code puis barre
     (25) X_TSTCT-TTEXT,                               "Description sur 25 caractères
     SY-VLINE.                                         "Barre verticale
  ENDIF.
  ENDLOOP.