🚀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

LECCIÓN 6 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.

Para evitar que se pisen los datos de la Tabla Interna, se usa la sentencia APPENDING TABLE en vez de INTO TABLE.

Es recomendable usar CLEAR y REFRESH antes de realizar la selección.

  • 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: obtenemos la primera ocurrencia dada una condición
  • 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.

Código Fuente Ejemplos:

*&---------------------------------------------------------------------* *& Report Z_PRUEBA_ABAP_3_7 *& *&---------------------------------------------------------------------* *& *& *&---------------------------------------------------------------------* REPORT z_prueba_abap_3_7. * Tabla interna de proveedores DATA: wa_usuarios TYPE ztabla_usuarios, ti_usuarios LIKE STANDARD TABLE OF wa_usuarios. DATA: BEGIN OF ti_usuarios_aux OCCURS 0, dni TYPE z_dni, END OF ti_usuarios_aux. DATA: BEGIN OF ti_usuarios2 OCCURS 0, nombre_ape TYPE z_nombre_ape, estado_usu TYPE z_estado_usu, END OF ti_usuarios2. DATA: v_estado_usu TYPE z_estado_usu, v_nombre_ape TYPE z_nombre_ape, v_dni TYPE z_dni, v_activos TYPE i. DATA: BEGIN OF ti_proveedores OCCURS 0, dni TYPE z_dni, END OF ti_proveedores. *---------------------------------------------------------------------* * Pantalla de selección *---------------------------------------------------------------------* PARAMETERS: p_nomape LIKE v_nombre_ape OBLIGATORY. SELECT-OPTIONS s_estado FOR v_estado_usu. *----------------------------------------------------------------------* START-OF-SELECTION. *----------------------------------------------------------------------* * Selecciono todos los registros SELECT * FROM ztabla_usuarios INTO TABLE ti_usuarios. * Selecciono de todos los registros el campo DNI SELECT dni FROM ztabla_usuarios INTO TABLE ti_usuarios_aux. * Selecciono el primer registro que cumpla la condición CLEAR wa_usuarios. SELECT SINGLE * FROM ztabla_usuarios INTO wa_usuarios WHERE nombre_ape NE space. * Selecciono el primer registro que cumpla la condición CLEAR v_dni. SELECT SINGLE dni FROM ztabla_usuarios INTO v_dni WHERE nombre_ape NE space. CLEAR ti_usuarios2. REFRESH ti_usuarios2. * Selecciono los registros que cumpla la condición SELECT nombre_ape estado_usu FROM ztabla_usuarios INTO CORRESPONDING FIELDS OF TABLE ti_usuarios2 WHERE nombre_ape NE space AND estado_usu = 'A'. * Selecciono los registros que cumplan con los parámetros de pantalla SELECT * FROM ztabla_usuarios INTO TABLE ti_usuarios WHERE nombre_ape = p_nomape AND estado_usu IN s_estado. * Obtengo el usuario activo con DNI más alto SELECT SINGLE MAX( dni ) INTO v_dni FROM ztabla_usuarios WHERE estado_usu = 'A'. * Obtengo la cantidad de usuarios activos SELECT COUNT(*) INTO v_activos FROM ztabla_usuarios WHERE estado_usu = 'A'. * Obtengo los registros de los usuarios que existan en la tabla * interna TI_PROVEEDORES SELECT * INTO TABLE ti_usuarios FROM ztabla_usuarios FOR ALL ENTRIES IN ti_proveedores WHERE dni = ti_proveedores-dni.


 

 

 


Sobre el autor

Publicación académica de Gustavo Bolivar, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP SemiSenior

Gustavo Bolivar

Profesión: Ing Sistemas - Chile - Legajo: EU47Z

✒️Autor de: 45 Publicaciones Académicas

🎓Egresado del módulo:

Presentación:

Enfocado en programación sap abap.

Certificación Académica de Gustavo Bolivar

✒️+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!