✒️ABAP El lenguaje SQL y la sentencia SELECT
ABAP El lenguaje SQL y la sentencia SELECT
La sentencia SELECT
ABAP Instrucciones Sql: la Sentencia Select
En ABAP existen un conjunto de sentencias que se utilizan para acceder a las tablas de la base de datos. La más importante de estas sentencias es SELECT.
A través de la sentencia SELECT podremos acceder a los registros almacenados en cada una de las tablas que componen a la base de datos de SAP.
La sentencia SELECT presenta muchas variantes de ejecución que utilizaremos en base a la necesidad de información que se nos requiera.
Algunos ejemplos de las variantes más utilizadas de la sentencia SELECT son las siguientes:
SELECT *: mediante esta sentencia se seleccionan todos los campos y todos registros de la tabla base de datos. Es aconsejable minimizar la utilización del SELECT * ya que consume muchos recursos del sistema
SELECT SINGLE: utilizaremos esta cláusula para seleccionar un solo registros de la tabla base de datos.
SELECT… INTO TABLE: mediante esta cláusula almacenaremos el resultado de la selección en la tabla interna que se especifique a continuación de TABLE.
SELECT… INTO CORRESPONDING FIELDS OF TABLE: mediante esta cláusula almacenaremos el resultado de la selección en la tabla interna que se especifique a continuación de TABLE pero esta tabla interna puede no tener la misma estructura que la tabla base de datos.
SELECT SINGLE MAX: mediante esta cláusula obtendremos el campo de mayor valor que se especifique a la derecha de MAX.
SELECT COUNT(*): utilizaremos esta sentencia si quisiéramos contabilizar la cantidad de registros que cumplen con una condición especifica.
SELECT….FOR ALL ENTRIES: utilizaremos esta sentencia si quisiéramos obtener de una tabla base de datos, todos los registros que existan en una tabla interna cargada con datos.:
Sentencia de ABAP que se utiliza para acceder a las bases de datos de SAP.
Sin dudas es la sentencia más popular o conocida en lo que se refiere a las tablas bases de datos.
Mediante esta sentencia podremos acceder a los registros almacenados en todas las tablas que componen a la base de datos.
Existen muchas variantes de ejecución de la sentencia SELECT, cada una de ellas la utilizaremos en base a la necesidad puntual de información que nos sea requerida.
Algunas de las opciones más utilizadas son:
SELECT *
SELECT SINGLE
SELECT...INTO TABLE
SELECT...INTO CORRESPONDING FIELDS OF TABLE
SELECT MAX
SELECT COUNT
SELECT...FOR ALL ENTRIES
IN
La cláusula ABAP IN se utiliza junto con la sentencia SELECT, cuando dentro de las condiciones de la selección se utiliza un SELECT-OPTIONS.
El objetivo de la utilización de IN en el SELECT es poder introducir un rango de valores en la selección a realizar.
Veamos a continuación un ejemplo:
SELECT z_instal z_secuencia z_motivo_stop z_ctacto z_aufnr z_fbaja
FROM ztu_stopfact_ods
INTO CORRESPONDING FIELDS OF TABLE it_stop
WHERE z_instal IN s_instal
AND z_motivo_stop = p_motivo
AND z_fbaja = v_fecha.
En donde S_INSTAL es un parámetro de tipo SELECT-OPTION perteneciente a la pantalla de selección del programa.
select-options: s_instal for eanl-anlage.
MAX
La cláusula ABAP MAX se utiliza junto con la sentencia SELECT cuando se quiere hallar el registro con el campo especificado de mayor valor numérico.
Veamos a continuación un ejemplo de su utilización:
SELECT ebeln MAX( budat )
INTO TABLE ti_budat
FROM ekbe
WHERE ebeln IN r_ebeln
GROUP BY ebeln.
Así como podemos buscar el máximo valor, también es posible buscar el mínimo valor y esto lo hacemos mediante SELECT MIN.
Veamos un ejemplo de su utilización a continuación:
DATA: v_minkwmeng TYPE kwmeng.
PARAMETERS: p_vbeln TYPE vbeln_va.
SELECT MIN( kwmeng ) FROM vbap INTO v_minkwmeng WHERE vbeln EQ p_vbeln.
Where
La palabra reservada de ABAP WHERE se utiliza para especificar las condiciones en diferentes sentencias del lenguaje.
Veamos a continuación algunos ejemplos de sentencias en donde utilizamos WHERE:
SELECT: en la sentencia SELECT utilizaremos la cláusula WHERE para acotar la selección de los datos de la tabla base de datos.
SELECT blart cpudt cputm stbel opbel ernam herkf
FROM dfkkko
INTO TABLE ti_compensacion
WHERE blart EQ 'RC'.
LOOP-ENDLOOP: en los bucles de interacción para acotar el recorrido de la tabla interna.
LOOP AT ti_log WHERE soc = '1000'
AND oper = '010'.
DELETE ti_log.
ENDLOOP.
Select-options
Es un objeto de la pantalla de selección ABAP que permite ingresar rangos de valores o valores individuales que se utilizarán para restringir el procesamiento y la salida de los datos posteriores.
El rango está compuesto por un valor "desde" y un valor "hasta".
La sintaxis del SELECT-OPTIONS es la siguiente:
SELECT-OPTIONS <s_nombre> FOR <tipo_datos>.
Cuando declaramos un select-options se creará una tabla interna con los siguientes campos:
SIGN: este campo contiene I o E, donde I representa un inclusivo (Incluir ese valor) y E es exclusivo (Excluir los valores), el valor por defecto es I.
OPTION: Este campo puede aceptar valores BT (Entre), NB (No Entre), EQ (Igual), NE (No igual), GT (Mayor que), LT (Menor que).
LOW: Este campo almacena el valor desde del rango.
HIGH: Este campo almacena el valor hasta alto del rango.
Veamos a continuación un ejemplo de su utilización:
DATA: v_werks_d TYPE werks_d.
SELECT-OPTIONS: s_zwerks FOR v_werks_d.
Existen muchas adiciones que se pueden agregar a la sentencia SELECT-OPTIONS, algunas de ellas son:
OBLIGATORY: para que el campo sea obligatorio.
NO INTERVALS: para que no se muestra el hasta.
NO-EXTENSION: para que solo se puede introducir un solo rango de valores.
Into Table
La claúsula ABAP INTO TABLE se utiliza junto con la sentencia SELECT y produce que los registros de las tablas base de datos que se seleccionan, se almacenarán en la tabla interna que se especifica a continuación de la sentencia.
Cuando trabajamos con la sentencia INTO TABLE debemos tener en consideración que los campos de la tabla interna que se utiliza a continuación de la sentencia deben tener el mismo formato y orden, de las columnas o campos de la tabla base de datos que se estan seleccionando mediante el SELECT.
Veamos un ejemplo:
SELECT * FROM SBOOK INTO TABLE itab1.
Si necesitamos realizar más de una selección a la misma tabla de la base de datos y queremos conservar los registros recuperados en todas las selecciones, entonces en lugar de utilizar la senetencia INTO TABLE vamos a utilizar la sentencia APPENDING TABLE que va a "agregar" los registros obtenidos en las siguientes selecciones al final de los registros obtenidos en la primera selección y asi consecutivamente.
Veamos un ejemplo:
SELECT * FROM SBOOK APPENDING TABLE itab1.
Count
La cláusula ABAP COUNT se utiliza junto con la sentencia SELECT cuando se quiere obtener la cantidad de registros de una tabla SAP.
Veamos un ejemplo de su utilización:
SELECT COUNT(*)
INTO v_total
FROM KNA1
WHERE LAND1 EQ 'ESP'.
Aquí lo que estamos haciendo es obtener la cantidad de registros existentes en la tabla KNA1 cuya "Clave de país" es 'ESP' que corresponde a España.
Es importante tener en cuenta que no hay espacio entre la palabra COUNT y el paréntesis.
Otra cláusula muy utilizada es SUM y nos permite sumarizar el contenido de todos los registros existentes para un campo de la tabla base de datos.
Single
La cláusula ABAP SINGLE se utiliza junto con la sentencia SELECT para seleccionar la primera ocurrencia que cumpla con las condiciones de la selección.
Veamos la sintaxis de la sentencia:
SELECT SINGLE <campo_1> <campo_2> <campo_n>
INTO <estructura>
FROM <tabla_base_de_datos>
WHERE <condiciones>.
Luego de la cláusula SINGLE podemos utilizar * (asterísco) para que se seleccionen todos los campos de la tabla base de datos.
Esta práctica no es recomendada por cuestiones de performance ya que si de la selección solo vamos a utilizar 10 campos, los 90 campos restantes que pueden componer a una tabla se recuperarían sin ninguna necesidad y esto se traduce en que la selección demorará más tiempo de lo necesario.
Into Corresponding Fields OF Table
La cláusula ABAP INTO CORRESPONDING FIELDS OF TABLE se utiliza junto con la sentencia SELECT y es necesaria si queremos utilizar un área de trabajo o estructura distinta al área de trabajo de la tabla base de datos leída.
De esta forma estamos especificando que que los campos seleccionados de la tabla base de datos deberán ser almacenados en los correspondientes campos de la tabla interna, es decir aquellos campos que tengan el mismo formato.
Veamos un ejemplo de su utilización:
TYPES: BEGIN OF ty_requeridos,
tabname LIKE dd03l–tabname,
fieldname LIKE dd03l–fieldname,
reftable LIKE dd03l–reftable,
END OF ty_requeridos.
DATA: ti_requeridos TYPE STANDARD TABLE OF ty_columnas.
SELECT tabname
fieldname
reftable
INTO CORRESPONDING FIELDS OF TABLE t_requeridos
FROM dd03l
WHERE tabname = c_tabname.
APPending Table
Cláusula ABAP que se utiliza junto con la sentencia SELECT y produce que los registros de las tablas que se seleccionan se añadan al final de la tabla interna sin pisar los registros preexistentes en la tabla interna.
Cuando se utiliza INTO, se eliminan todas las líneas existentes en la tabla .
Los campos en la tabla interna no se ve afectado por la selección se llenan con los valores iniciales.
 
 
 
Sobre el autor
Publicación académica de Nestor Adrian Lara, en su ámbito de estudios para la Carrera Consultor ABAP.
Nestor Adrian Lara
Profesión: Diseño Gráfico - Argentina - Legajo: BZ89W
✒️Autor de: 11 Publicaciones Académicas
🎓Egresado del módulo:
Certificación Académica de Nestor Lara