🚀PROMO #PLANCARRERA2024 - 🔥Bonificaciones, Precios Congelados y Cuotas

 X 

✒️ABAP El lenguaje SQL y la sentencia SELECT

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.

SAP Junior

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

✒️+Comunidad Académica CVOSOFT

Continúe aprendiendo sobre el tema "El lenguaje SQL y la sentencia SELECT" de la mano de nuestros alumnos.

SAP Master

SENTENCIA SELECT INTO TABLE se utiliza cuando el resultado de la consulta se guarda en una tabla interna simepre despues de un select se debe preguntar por el sy-subrc para saber como proseguir SENTENCIA SINGLE para obtener la primera ocurrencia de la tabla clausula in para select option FOR ALL ENTRIES IN es un formato especial de la sentencia where que se utiliza para especificar condiciones en tiempo de ejecucion no se pueden utilizar like between e in

Acceder a esta publicación

Creado y Compartido por: Andres Felipe Escobar Lopez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

La sentencia SELECT. SELECT: Sentencia ABAP que se utiliza para acceder a las bases de datos a SAP. Tabla interna: Es un objeto de datos que permite guardar en memoria grandes cantidades de registros de datos con la misma estructura. La cantidad de registros máxima esta relacionada con los límites especificados en la instalación del sistema. INTO TABLE: Cláusula ABAP que se utiliza con la sentencia SELECT y produce que los registros de las tablas que se seleccionan se ve la tabla interna que se especifica a continuación. APPENDING TABLE: Cláusula ABAP que se utiliza con la sentencia SELECT y produce que los registros de las tablas que se seleccionan se añadan al final de la tabla interna...

Acceder a esta publicación

Creado y Compartido por: Rafael Razo

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

SELECT: Sentencia ABAP que se utiliza para acceder a las BD. SINTAXIS: SELECT <CAMPOS A SELECCIONAR> FROM <TABLA DONDE SE REALIZARA RA BÚSQUEDA> INTO <DESTINO DE LOS DATOS> INTO TABLE <SE UTILIZA SI EL DESTINO DE LOS DATOS ES UNA TABLA INTERNA> WHERE <CONDICIONES DE LA BÚSQUEDA> APPENDING TABLE: SE UTILIZA CON EL SELECT PARA INDICAR QUE LOS DATOS SE DEBEN INGRESAR AL FINAL DE LA TABLA INTERNA Y NO SIN PISAR LOS YA EXISTENTES EN ELLA. SINGLE: ESTA CLAUSULA QUE SE UTILIZA CON EL SELECT PARA SELECCIONAR EL PRIMER REGISTRO QUE CUMPLA CON LAS CONDICIONES DE BÚSQUEDA. INTO CORRESPONDING FIELDS OF TABLE: CLAUSULA ABAP QUE SE UTILIZA CON UN SELECT Y ES NECESARIA SI QUEREMOS UTILIZAR UN ÁREA...

Acceder a esta publicación

Creado y Compartido por: Juan Santamaria Borja

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Expert


1) SENTENCIA SELECT SELECT es la sentencia que se utiliza para leer los datos de una tabla de la BD. Sintaxis: SELECT <campos> FROM <tabla> INTO <target> where <condiciones>. Existen muchas cláusulas que se pueden utilizar en el SELECT: Si necesitamos que el resultado de la consulta se guarde en una tabla interna: SELECT * FROM ztabla_usuarios INTO TABLE ti_usuarios. Si necesitamos conservar el contenido de la tabla interna luego de reiteradas selecciones. SELECT * FROM ztabla_usuarios APPENDING TABLE ti_usuarios. Utilizar CLEAR y REFRESH a la tabla interna antes de la selección Si se desea obtener el campo DNI de todos los campos de la tabla...

Acceder a esta publicación

Creado y Compartido por: Maria Guadalupe Gonzalez Sanchez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

una sentencia peculiar de ABAP en el uso de tablas es: CORRESPONDING FIELDS OF TABLE, se utliza con la sentencia SELECT y es necesaria si se quiere usar un area de trabajo con diferente estructura a el area de trabajo de la tabla leida. La sentencia FOR ALL ENTRIES IN, es util para buscar las coincidencias de una tabla interna en una tabla base de datos

Acceder a esta publicación

Creado y Compartido por: Carolina Sanchez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP SemiSenior

LA SENTENCIA SELECT: Sentencia que se usa para accesar a los datos. SELECT <resultado FROM <tabla> into <target> (es el destino donde serán alojados los datos). WHERE <conditios>. SELECT * FROM ztabla_usuarios INTO TABLE ti_usuarios. INTO TABLE (los registros seleccionados se colocan en la tabla interna). (el INTO puede ir antes o después del FROM). APPENDING TABLE (los registros seleccionados se colocan en la tabla interna PERO sin borrar los que ya se tenían almancenados). Es recomendable usar CLEAR y REFRESH de la tabla interna antes de realizar la selección. SINGLE (selecciona la primer ocurrencia de la consulta) es como traer el TOP en SQL, CLEAR wa_usuarios. SELECT SINGLE * FROM ztabla_usuarios...

Acceder a esta publicación

Creado y Compartido por: Gerardo De La Rosa Rivera

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Senior

Instrucciones SQL: La sentencia SELECT 1. La sentencia SELECT Se utiliza para acceder a la base de datos SELECT <campos> FROM <tabla > INTO <target> WHERE <condiciones> La cláusula INTO TABLE se utiliza cuando el resultado de la consulta se guarda en una tabla interna. Si queremos conservar el contenido de la tabla interna utilizamos la cláusula APPENDING TABLE en lugar de INTO TABLE y agrega los registros al final. Es recomendable hacer CLEAR y REFRESH de la tabla interna antes de realizar la selección. Siempre después de un SELECT se debe preguntar por el SY-SUBRC para saber como proseguir. Si quisiéramos obtener la primera ocurrencia de la tabla ZTABLA_USUARIOS donde se cumpla determinada...

Acceder a esta publicación

Creado y Compartido por: Pedro Alejandro Arroyo Gutierrez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

Sentencias ABAP que se utilizan para acceder a la base de datos: SELECT <resultado> FROM <tabla> INTO TABLE <target> WHERE <condiciones>. Evitar el uso del * cuando solo se requiera obtener algunos campos de la tabla origen. Es una buena práctica. Es recomendable hacer CLEAR y REFRESH de la tabla interna antes de realizar la selección. Si necesitamos conservar el contenido de la tabla interna a la que haremos el SELECT ... INTO tablainterna tenemos que usar la cláusula APPENDING TABLE en lugar de INTO TABLE. APPENDING TABLE: cláusula que se usa 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...

Acceder a esta publicación

Creado y Compartido por: Jose Ignacio Rodini

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Master

1- La sentencia SELECT SELECT <resultado> "En resultado se colocan los campos que se quieren recuperar" FROM <tabla> "Es la tabla origen de donde se secan los datos" INTO <target> "Es el destino donde serán alojados los datos" WHERE <condiciones> "Condiciones de la búsqueda" Es recomendable hacer CLEAR y REFRESH de la tabla interna antes de realizar la selección. Otras clausulas: SINGLE: Para obtener la primera ocurrencia de una tabla. INTO CORRESPONDING FIELDS OF TABLE: Para obtener los registros de una tabla interna en una tabla que no tiene la misma estructura IN: Se utiliza para los select-options en...

Acceder a esta publicación

Creado y Compartido por: Calixto Gutiérrez

*** CVOSOFT - Nuestros Alumnos - Nuestro Mayor Orgullo como Academia ***

SAP Expert


CLEAR WA_USUARIOS. REFRESH TI_SFLIGHT. SENTENCIAS SELECT SELECT * FROM SFLIGHT INTO TABLE TI_SFLIGHT WHERE S_FLIGHT-FLIGHT ='001'. Si quisieramos obtener de una tabla los registros que cumplan una condicion pero queremos guardarlos en una tabla interna que no tiene la misma estructura que la tabla, entonces tenemos que usar la clausula INTO CORRESPONDING FIELDS OF TABLE. Se utiliza con un area de trabajo al area utilizada para leer la tabla, Realiza la comparacion de los campos teniendo en cuenta los tipos de los campos de cada tabla y la posicion de cada uno de ellos (ej: un campo de tipo char de 4 posiciones en cada tabla). La clausula IN se utiliza para los select-options en las condiciones de un select. ej: select * from ztabla_usuarios...

Acceder a esta publicación

Creado y Compartido por: Oscar Guillermo Rodriguez Villate / Disponibilidad Laboral: FullTime

 


 

👌Genial!, estos fueron los últimos artículos sobre más de 79.000 publicaciones académicas abiertas, libres y gratuitas compartidas con la comunidad, para acceder a ellas le dejamos el enlace a CVOPEN ACADEMY.

Buscador de Publicaciones:

 


 

No sea Juan... Solo podrá llegar alto si realiza su formación con los mejores!