✒️ABAP El lenguaje SQL y la sentencia SELECT
ABAP El lenguaje SQL y la sentencia SELECT
El lenguaje SQL y la sentencia SELECT
1. El lenguaje SQL
SQL (Lenguaje de Consulta Estructurado) es un lenguaje de consulta, usado como interfaz para comunicarse con bases de datos y realizar operaciones de acceso y manipulación de la información almacenada.
Las sentencias del lenguaje SQL pueden ser clasificadas en tres grupos que son los siguientes:
Lenguaje de Definición de datos (DDL): Se utiliza para definir estructuras como el esquema, la base de datos, las tablas de la base de datos, las restricciones, etc.
Para definir las estructuras disponemos de tres sentencias:
- CREATE: se utiliza para crear una base de datos, tablas bases de datos, vistas, etc.
- ALTER: se utiliza para modificar la estructura de la base de datos, por ejemplo, añadir o borrar columnas de una tabla base de datos.
- DROP: con esta sentencia podemos eliminar los objetos de la estructura, por ejemplo un índice o una secuencia.
Lenguaje de Manipulación de datos (DML): Permite a los usuarios introducir datos para posteriormente realizar tareas de consulta o modificación de los datos que contienen las bases de datos.
- SELECT: esta sentencia se utiliza para realizar consulta sobre los datos.
- INSERT: con esta sentencia podemos insertar los valores en una tabla base de datos.
- UPDATE: se utiliza para modificar los valores de uno o varios registros.
- MODIFY: también se utiliza para modificar los valores de uno o varios registros.
- DELETE: se utiliza para eliminar las filas de una tabla base de datos.
Lenguaje de Control de Datos (DCL): gracias a este lenguaje podemos darle o quitarle permisos sobre los objetos a los usuarios que se conectan a la base de datos.
Los comandos para controlar los permisos son los siguientes:
- GRANT: permite otorgar permisos.
- REVOKE: elimina los permisos que previamente se han concedido.
2. La sentencia SELECT
Se utiliza para recuperar información en SQL, es decir, permite obtener registros de la base de datos, de una o varias tablas combinadas. Además, permite hacer filtrados de información, para obtener únicamente los registros que cumplen ciertas condiciones.
En ABAP la sentencia SELECT tiene la siguiente sintaxis:
SELECT <resultado> "En resultados se colocan los campos que se desean recuperar"
FROM <tabla> "Es la tabla base de datos de donde se sacan los datos"
INTO <target> "Es el destino donde serán alojados los datos"
WHERE <condiciones>. "Condiciones de la búsqueda"
Existen distintas variantes de SELECT, a continuación las comentamos:
2.1 SELECT * INTO TABLE
Con el símbolo del asterisco * podemos indicar que queremos todos los registros de la tabla. INTO TABLE se utiliza cuando el resultado de la consulta se guarda en una tabla interna.
Código de ejemplo:
SELECT *
FROM ztabla_usuarios
INTO TABLE ti_usuarios.
Importante: Se debe evitar el uso del * cuando solo se requiere obtener algunos de los campos de la tabla origen.
2.2. SELECT * APPENDING TABLE
Con APPENDING TABLE en lugar de INTO TABLE lo que hacemos es añadir los registros de la base de datos a la tabla interna, sin eliminar los registros de la tabla interna ya existentes.
Código de ejemplo:
SELECT *
FROM ztabla_usuarios
APPENDING TABLE ti_usuarios.
Es recomendable hacer un REFRESH de la tabla interna en donde se almacenarán los datos antes de realizar la selección de los mismos. En caso de utilizar una variable o una estructura entonces deberemos ejecutar un CLEAR.
2.3 SELECT campo1
Para seleccionar solamente un campo de una base de datos, utilizamos una tabla auxiliar solamente con el campo deseado, por ejemplo DNI.
Código de ejemplo:
SELECT dni
FROM ztabla_usuarios
INTO TABLE ti_usuarios_aux.
Siempre después de un SELECT se debe preguntar por el SY-SUBRC para saber cómo proseguir.
Si quisiéramos obtener dos campos de la tabla base de datos, entonces debemos escribir luego de la sentencia select el nombre de los campos, en el mismo orden en el que dichos campos se encuentran en la tabla base de datos. Si donde vamos a almacenar los datos no coincide en el formato con los datos recuperados, entonces se produce un error.
2.4 SELECT SINGLE
Si deseamos obtener la primera ocurrencia de una tabla entonces debemos ejecutar un SELECT SINGLE *.
Código de ejemplo:
CLEAR wa_usuarios.
SELET SINGLE *
FROM ztabla_usuarios
INTO wa_usuarios
WHERE nombre_ape NE space.
El resultado de esta consulta será guardado en la estructura WA_USUARIOS que es del mismo tipo que la tabla ZTABLA_USUARIOS. Si quisiéramos realizar la misma consulta anterior, pero necesitamos saber solamente un campo, entonces deberíamos de almacenar el resultado en una variable.
Código de ejemplo:
CLEAR v_dni.
SELECT SINGLE dni
FROM ztabla_usuarios
INTO v_dni
WHERE nombre_ape NE space.
2.5 SELECT INTO CORRESPONDING FIELDS OF TABLE
Si queremos obtener de una tabla base de datos los registros que cumplan una condición pero deseamos guardarlos en una tabla interna que no tiene la misma estructura que la tabla base de datos, entonces tenemos que usar la cláusula INTO CORRESPONDING FIELDS OF TABLE.
Código de ejemplo:
SELECT nombre_ape estado_usu
FROM ztabla_usuarios
INTO CORRESPONDING FIELDS OF TABLE ti_usuarios2
WHERE nombre_ape NE space
AND estado_usu EQ 'A'.
2.6 SELECT ...WHERE IN
Si quisiéramos hacer una selección de una tabla base de datos en base a lo que los usuarios ingresan por pantalla, haríamos lo siguiente.
Código de ejemplo:
SELECT *
FROM ztabla_usuarios
INTO TABLE ti_usuarios
WHERE nombre_ape EQ p_nomape
AND estado_usu IN s_estado.
La cláusula IN se utiliza para los select-options en las condiciones de un select.
2.7 SELECT MAX
Si quisiéramos obtener el usuario activo con DNI más alto, tendríamos que usar la cláusula MAX de la siguiente forma.
Código de ejemplo:
CLEAR v_dni.
SELECT SINGLE MAX dni
INTO v_dni
FROM ztabla_usuarios
WHERE estado_usu EQ 'A'.
2.8 SELECT COUNT
Si queremos contar la cantidad de usuarios con estado activo, debemos usar la cláusula COUNT de la siguiente forma.
Código de ejemplo:
CLEAR v_activos.
SELECT COUNT (*)
INTO v_activos
FROM ztabla_usuarios
WHERE estado_usu EQ 'A'.
2.9 SELECT FOR ALL ENTRIES IN
Si quisiéramos obtener de una tabla todos los registros que existan en una tabla interna cargada con datos, entonces debemos utilizar FOR ALL ENTRIES IN que nos permite especificar condiciones en tiempo de ejecución.
Código de ejemplo:
SELECT *
INTO TABLE ti_usuarios
FROM ztabla_usuarios
FOR ALL ENTRIES IN ti_proveedores
WHERE dni EQ ti_proveedores-dni.
2.10 SELECT ...LIKE
Si quisiéramos obtener todos los registros que cumplan un patrón de texto en alguno de sus campos, debemos utilizar la cláusula LIKE.
Código de ejemplo:
SELECT *
FROM ztabla_usuarios
INTO TABLE ti_usuarios
WHERE nombre_ape LIKE 'A%'.
2.11 SELECT ...INNER JOIN
Tenemos la posibilidad de realizar un SELECT a más de una tabla base de datos, lo que se conoce con el nombre de JOIN. Para analizar este punto vamos a trabajar con dos tablas bases de datos muy importantes dentro del sistema SAP, como son la tabla de datos estándar VBRK de Factura: Datos de cabecera y la tabla base de datos estándar VBRP de Factura: Datos de posición.
Supongamos que deseamos recuperar de ambas tablas base de datos los registros en donde el campo VBELN (Número de factura) coincida, esta será la condición de unión entre ambas tablas y para estos registros nos vamos a quedar con los siguientes campos de la tabla base de datos VBRK:
Factura (VBELN)
Clase de factura (FKART)
Tipo de factura (FKTYP)
Tipo de documento comercial (VBTYP)
Moneda del documento comercial (WAERK)
Organización de ventas (VKORG)
Canal de distribución (VTWEG)
Y los siguientes campos de la tabla base de datos VBRP:
Posición de factura (POSNR)
Valor neto de posición de factura (NETWR)
Entonces vamos a ejecutar la sentencia SELECT INNER JOIN de la siguiente forma.
Código de ejemplo:
TYPES: BEGIN OF ty_facturas,
vbeln LIKE vbrk-vbeln,
fkart LIKE vbrk-fkart,
fktyp LIKE vbrk-fktyp,
vbtyp LIKE vbrk-vbtyp,
waerk LIKE vbrk-waerk,
vkorg LIKE vbrk-vkorg,
vtweg LIKE vbrk-vtweg,
posnr LIKE vbrp-posnr,
netwr LIKE vbrp-netwr,
END OF ty_facturas.
DATA: ti_facturas TYPE STANDARD TABLE OF ty_facturas,
wa_facturas LIKE LINE OF ti_facturas.
SELECT t1~vbeln t1~fkart t1~fktyp t1~vbtyp t1~waerk
t1~vkorg t1~vtweg t2~posnr t2~netwr
INTO CORRESPONDING FIELDS OF TABLE ti_facutras
FROM vbrk AS t1 INNER JOIN vbrp AS t2
ON t2~vbeln = t2~vbeln.
La cláusula INNER JOIN entre dos tablas base de datos A y B entregará el resultado de la intersección de los conjuntos A y B. En otras palabras, la parte interna, es decir, los registros en común entre ambas tablas de base de datos según la condición de conexión entre ambas.
También tenemos disponible en ABAP la cláusula LEFT OUTER JOIN entre dos tablas base de datos A y B, en donde obtendremos como resultado la unión entre las tablas A y B más la parte de información exterior de la tabla base de datos A, es de la tabla base de datos que se encuentre a la izquierda en la unión.
 
 
 
Sobre el autor
Publicación académica de Manel Gangolells Isanta, en su ámbito de estudios para la Carrera Consultor ABAP.
Manel Gangolells Isanta
Profesión: Técnico de Sistemas Informáticos - España - Legajo: MN13W
✒️Autor de: 33 Publicaciones Académicas
🎓Cursando Actualmente: Consultor ABAP Nivel Inicial
Certificación Académica de Manel Gangolells