✒️ABAP Los Field Symbols
ABAP Los Field Symbols
Field Symbols ¿Qué son los Field Symbols?
NUEVO CONCEPTO: FIELD SYMBOL
Es un tipo de sentencia ABAP que nos permite trabajar con los datos de los programas en forma dinámica en tiempo de ejecución.
Al contrario de lo que sucede con el acceso estático de los datos, donde necesitamos especificar el nombre de un objeto para poder hacer algo con él, los Field Symbol nos permiten acceder y pasar datos cuyos nombres y atributos no conocemos hasta el momento de la ejecución.
Se puede considerar a los Field Symbol como nombres simbólicos de los datos, ya que cuando se utilizan, el sistema trabaja con el contenido de los datos asignados y no con el contenido del field symbol.
Los Field Symbol nos proveen de gran flexibilidad debido a que:
- Si queremos procesar partes de campos, nos permiten especificar el offset y el desplazamiento de un campo en forma dinámica.
- Se puede forzar a un Field Symbol para que tome diferentes atributos técnicos que los del campo asignado a él.
IMPORTANTE: La mayoría de los errores que cometamos en la utilización de Field Symbols los detectaremos recién en tiempo de ejecución. Esto hace que sean bastante más difíciles de detectar. Por lo tanto, solo debemos utilizar Field Symbol si no podemos llegar al mismo resultado con las sentencias ABAP convencionales.
Declaración de un Field SymbolPara declarar un Field Symbol vamos a utilizar la siguiente sintaxis:
SABIAS QUE... Si no especificamos un tipo a un Field Symbol, este puede contener cualquier dato. Cuando asignamos un dato al Field Symbol, este hereda los atributos técnicos del dato.
Los tipos de datos genéricos posibles para un Field Symbol son:
TIPO DE ESPECIFICACIÓN:
Objeto de dato
TYPE ANY o sin especificación
Todos los tipos de objetos de datos son aceptados. El field symbol adopta los atributos del dato.
TYPE C, N, P o X
Solo los tipos de datos C, N, P y X son aceptados. El field symbol adopta la longitud y decimales del dato.
TYPE TABLE
El sistema chequea si la tabla es estándar.
TYPE ANY TABLE
El sistema chequea si el campo es una tabla interna. El field symbol hereda todos los atributos de la tabla.
TYPE INDEX TABLE
El sistema chequea si el campo es una tabla indexada. El field symbol hereda todos los atributos de la tabla.
TYPE STANDARD TABLE
El sistema chequea si el campo es una tabla estándar. El field symbol hereda todos los atributos de la tabla.
TYPE SORTED TABLE
El sistema chequea si el campo es una tabla sorted. El field symbol hereda todos los atributos de la tabla.
TYPE HASHED TABLE
El sistema chequea si el campo es una tabla hashed. El field symbol hereda todos los atributos de la tabla.
Veamos un ejemplo de la utilización de un Field symbol:
AUDIO TIPS: Existen distintos tipos de tablas internas. Por ejemplo ANY TABLE. Es posible usar una ANY TABLE para definir el tipo de un parámetro de tabla genérico. Las operaciones permitidas para tablas de tipo ANY TABLE son todas las operaciones permitidas para estándar SORTED Y HASHED TABLE. Hay que tener en cuenta que no es posible usar índices para acceder a las tablas definidas con este tipo. Otro tipo de tabla interna es la INDEX TABLE. Los tipos STANDARD y SORTED pertenecen al tipo de tabla genérico INDEX TABLE. Una tabla indexada es aquella a la que podemos acceder mediante un índice. Es posible usar el tipo INDEX TABLA para especificar el tipo de un parámetro genérico en un FORM o en una FUNCTION o sea en una función. El tipo HASHED no pertenece al tipo GLOBAL INDEX por lo que no puede ser pasado un parámetro definido INDEX TABLE. Otro tipo de tablas internas son las STANDARD TABLE. El acceso a una STANDARD TABLE es mediante una búsqueda lineal. Esto significa que el tiempo requerido para la búsqueda está relacionado linealmente al número de registros de la tabla. Otro tipo de tabla interna es la SORTED TABLE. Al definir una tabla como SORTED TABLE, esta tabla siempre se guarda con el orden correcto. El acceso a una SORTED TABLE es mediante una búsqueda binaria o BINARY SEARCH. Si la clave no es única el sistema obtiene la entrada con el índice más bajo. El tiempo requerido para el acceso está logaritmicamente relacionado al número de registros de la tabla. También es posible acceder a SORTED TABLES mediante operaciones de índices. Y por último tenemos la HASHED TABLE Podemos entender una HASHED TABLE como un grupo a cuyos elementos se pueden acceder usando una clave única. A diferencia de los tipos STANDARD y SORTED no podemos acceder a estas tablas mediante índices. Todos los registros deben tener una clave única y el tiempo de acceso es constante sin tener en cuenta el número de registros de la tabla. Solo es posible acceder a estas tablas tipo HASHED usando las operaciones genéricas de clave u otras operaciones genéricas tales como SORT o LUC.
Asignación de datos a un Field SymbolsPara asignar datos a un Field Symbol utilizamos la sentencia ASSIGN.
La asignación que utilizamos es estática ya que sabemos el nombre del campo que queremos asignar al Field Symbol.
 
 
 
Sobre el autor
Publicación académica de Vismark Eyner Sevillano Moreno, en su ámbito de estudios para la Carrera Consultor ABAP.
Vismark Eyner Sevillano Moreno
Profesión: Tecnologo en Sistemas - Colombia - Legajo: KN43C
✒️Autor de: 62 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Aprender todo lo relacionado con programación sap abap, para desenvolverme en el área laboral en el sector de programación abap.
Certificación Académica de Vismark Sevillano