✒️ABAP HANA ABAP Core Data Services
ABAP HANA ABAP Core Data Services
1 Introducción a la programación avanzada de BD con ABAP 7.4
Como sabemos, para utilizar el paradigma code-to-data en ABAP, necesitamos implementar y ejecutar la lógica de procesamiento en la base de datos. Para este fin se dispone de una serie de objetos de desarrollo de SAP HANA, los cuales solo se encuentran disponibles en Eclipse y pueden ser creados mediante el SAP HANA Studio, entre los cuales podemos mencionar los siguientes:
- Procedimientos de base de datos
- Vistas de atributos
- Vistas analíticas
- Vistas de cálculo
Sin embargo, el uso de estos objetos puede ocasionar algunos problemas ya que, a diferencia de los objetos administrados por el AS ABAP, existen restricciones que aplican a los objetos de desarrollo de SAP HANA.
Podemos mencionar las siguientes restricciones o desventajas de los objetos de desarrollo de SAP HANA:
- No se integran completamente con la gestión del ciclo de vida de ABAP. Es decir, si modificamos un objeto de desarrollo en SAPA HANA Studio entonces debemos sincronizar manualmente los cambios realizados en el ABAP DDIC.
- No se consideran en la verificación de sintaxis y activación de una aplicación o programa ABAP. Esto significa que el entorno en tiempo de ejecución no muestra errores y advertencias relacionados con las implementaciones de objetos de desarrollo de SAP HANA.
- No pueden extenderse o ampliarse, algo que si podemos llevar a cabo con las tablas de base de datos existentes en el ABAP DDIC.
- Los desarrolladores ABAP requieren un usuario adicional para la base de datos de SAP HANA y las autorizaciones correspondientes.
A partir de ABAP 7.4 se introducen una serie de mejoras en el lenguaje que permita garantizar la integración de los objetos en el ciclo de vida ABAP, incluída la gestión de versiones y posibilidad de extender o ampliar los objetos. Las mas relevantes son:
- CDS: Las Core Data Services son un método específico de SAP que se utilizan para definir modelos de datos persistentes.
- Nuevas características de OpenSQL: Estas incluyen por ejemplo, el soporte de expresiones SQL en el SELECT y en cláusulas GROUP BY, HAVING y WHERE.
- Implementación de procedimientos de base de datos SAP HANA en métodos ABAP: Los procedimientos administrados ABAP (AMDP) nos permiten ejecutar la lógica de procesamiento en la base de datos. Podemos implementar estos procedimientos en el entorno de desarrollo ABAP normal sin requerir un usuario para la base de datos SAP HANA.
2 ABAP Core Data Services
La especificación CDS se basa en los estándarse SQL-92 y SQL:1999. El objetivo es facilitar la implementación de los modelos de datos desarrollados en la fase de diseño. Cabe indicar que estan disponibles en el AS ABAP a partir de SAP NW ABAP 7.4 SP05, antes de esa versión solo era posible crear vistas CDS como objeto de desarrollo en SAP HANA.
Al igual que SQL, las CDS definen:
- Un lenguaje de control de datos (DDL): Para describir tablas y tipos estructurados.
- Un lenguaje de control de datos (DCL): Para definir restricciones de acceso.
- Un lenguaje de consulta (QL): Para leer datos de una manera cómoda y se utiliza en combinación con DDL para definir vistas de base de datos.
Las CDS también contienen las siguientes mejoras:
- Anotaciones: Para enriquecer los objetos CDS con metadatos adicionales que no se pueden expresar en SQL. Estos metadatos también pueden ser consultados y utilizados por las aplicaciones clientes.
- Tipos de datos definidos por el usuario, escalares y estructurados: Para ilustrar mejor la semántica de los tipos de datos utilizados.
- Asociaciones: Para definir relaciones entre los objetos CDS. En el modelado y consulta podemos utilizar expresiones de ruta para abordar las relaciones que se han descrito con las asociaciones.
Debido a que los datos de las soluciones SAP ya estan almacenados en tablas, el enfoque de las ABAP CDS es la creación de vistas de los datos comerciales existentes. Estas vistas sientan las bases para la aceleración de los programas ABAP existentes y el desarrollo de aplicaciones nuevas e innovadoras.
En SAP S/4HANA, por ejemplo, los datos comerciales se proporcionan mediante vistas CDS y permiten que las nuevas aplicaciones cliente accedan a interfaces claras y consistentes y se beneficien de la reducción de código de estas vistas.
Cabe indicar que se pueden reutilizar los modelos de datos existentes y objetos DDIC en las ABAP CDS. Por lo tanto, podemos decir que las ABAP CDS son una extensión del diccionario de datos y los objetos SQL definidos en el DDIC.
2.1 HANA CDS vs ABAP CDS
Veamos a continuación las características que diferencia a ambas implementaciones:
HANA CDS | ABAP CDS |
|
|
2.2 ABAP CDS vs Vistas de la transacción SE11
¿Qué ventajas tienen las vistas ABAP CDS contra las vistas tradicionales del DDIC? Para responder, haremos uso de una tabla:
Características | ABAP CDS | VISTAS DDIC |
Parámetros de entrada | Si | No |
SQL Joins (inner, left outer, right outer) | Si | Si, limitado |
Agrupar resultados (UNION / UNION ALL) | Si | No |
Funciones de agregación (SUM, MAX, AVG, COUNT...) | Si | No |
Cláusulas SELECT (Where, Group By, HAVING) | Si | No |
Operaciones aritméticas sobre columnas | Si | No |
Insertar literales en la selección | Si | No |
Funciones de conversión de fechas | Si | No |
Expresiones condicionales (CASE) | Si | No |
Asociación de tablas | Si | No |
Anotaciones | Si | No |
Path expressions | Si | No |
2.3 Pasos para crear y consumir una vistas ABAP CDS
1.Seleccionamos el proyecto ABAP donde queramos crear la vista
2. Localizamos el paquete donde vamos a crear la vista, damos clic con el botón derecho del mouse sobre el paquete y elegimos la opción New->Other ABAP Repository Object
3. Seleccionamos el objeto Data Definition (o DDL Source dependiendo de la versión) dentro de la carpeta Core Data Services
4. Completamos el nombre de la vista CDS y la descripción
5. Seleccionamos una orden de transporte existente o creamos una nueva orden
6. Por defecto tenemos varias plantillas disponibles para crear las vistas ABAP CDS. Una de ellas que podemos seleccionar es Define View y hacer clic en Finalizar
7. Se abrirá un editor con el código generado por la plantilla que tiene todo lo necesario para definir una nueva vista
8. Para implementar la vista debemos:
- Cambiar el texto "sql_view_name" por el nombre que tendra la vista en el DDIC ABAP. Es importante indicar que este nombre NO PUEDE ser el mismo indicado en el paso 4.
- Reemplazar "data_source_name" por el nombre de la tabla de base de datos de donde se esta creando la vista
- En este caso, para referencia los campos se utiliza el punto (.) en lugar de (~) como se acostumbra en OpenSQL
- Las columnas que recuperamos en la consulta se definen dentro de las llaves { }
- Después de las llaves { } podemos incluir la cláusula WHERE
- Los comentarios empiezan por // para una línea o /* */ para un bloque
9. Finalmente grabamos y activamos la vista
En el DDIC ABAP, las vistas ABAP CDS se denominan Vistas SQL DDL. Una vez se haya activado, ya esta disponible para verla desde la Tx SE11, ejecutarla y acceder a su definición en SQL desde el menú Detalles->ABAP Create pero no se puede modificar la vista desde el DDIC, solo desde Eclipse.
Desde nuestras aplicaciones ABAP, las vistas pueden consumirse con sentencias OpenSQL como cualquier tabla o vista del DDIC. También puede utilizarse como tipo para definir tablas internas, estructuras y variables de los programas ABAP. Para ello, debemos utilizar el nombre que especificamos en el atributo sqlViewName y no el nombre de la vista ABAP CDS.
2.4 ¿Cómo encontramos las vistas ABAP CDS creadas en el sistema SAP?
Podemos consultar la tabla estándar TADIR con los siguientes parámetros de selección de tal forma que podamos encontras todas las vistas CDS existentes en SAP, su nombre en el DDIC ABAP y el paquete al que pertenecen. Los parámetros a indicar son:
- PGMID = R3TR
- OBJECT = DDLS
Accediendo a la tabla DDLDEPENDENCY podemos obtener los nombre de la vista en el DDIC ABAP y en SAP HANA. Para ello, accedemos con el parámetro:
- OBJECTTYPE = VIEW
Tips:
- Una característica importante de la especificación CDS es que su implementación es independiente de la base de datos. Esto significa que igual que OpenSQL, las ABAP CDS se pueden ejecutar en cualquier base de datos compatible.
 
 
 
2 Agradecimientos:
Han agradecido este aporte: Jesús Quiñonez López, Martín Gómez Rodríguez
Sobre el autor
Publicación académica de Abraham Humberto Noriega Cabrera, en su ámbito de estudios para el Máster ABAP for HANA.
Abraham Humberto Noriega Cabrera
Profesión: Ingeniero Sistemas Computacionales - Mexico - Legajo: WO62V
✒️Autor de: 14 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Ingeniero en sistemas computacionales con experiencia en análisis, desarrollo e implementación de sistemas. he tenido el gusto de participar en implementaciones tanto locales como a nivel estatal.
Certificación Académica de Abraham Noriega