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

 X 

✒️ABAP La performance en ABAP

ABAP La performance en ABAP

ABAP La performance en ABAP

Comparación de Performance de SQL

Hola Compañeros:

Os dejo aquí el código fuente de un análisis de performance de SQL configurable mediante el uso de buenas y malas practicas en la sentencia SELECT. El tiempo y los registros recuperados aparecen en la barra de estado con un mensaje de STATUS. La consulta es un cuádruple JOIN con selección. Yo no percibo grandes aumentos de rencimiento, tan solo un 15%-20% entre el peor y el mejor caso.

  1. *&---------------------------------------------------------------------*
  2. *& Report ZGZ57B_SQL_PERFORMANCE
  3. *&
  4. *&---------------------------------------------------------------------*
  5. *&
  6. *&
  7. *&---------------------------------------------------------------------*
  8. REPORT zgz57b_sql_performance.
  9. *---------------------------------------------------------------------*
  10. * Tablas de la Base de Datos SAP
  11. *---------------------------------------------------------------------*
  12. TABLES:
  13. kna1, "Maestro Clientes
  14. t005t, "Nombre de los Paises
  15. vbak, "Cabeceras de Pedido
  16. vbap. "Lineas de Pedido
  17. *---------------------------------------------------------------------*
  18. * Tipos para las Tablas de los Informes
  19. *---------------------------------------------------------------------*
  20. TYPES:
  21. BEGIN OF ty_detalle,
  22. land1 LIKE kna1-land1, "Codigo Pais
  23. landx LIKE t005t-landx, "Nombre Pais
  24. ort01 LIKE kna1-ort01 , "Ciudad
  25. kunnr LIKE kna1-kunnr , "Codigo Cliente
  26. name1 LIKE kna1-name1 , "Nombre Cliente
  27. vbeln LIKE vbak-vbeln, "Num.Pedido
  28. audat LIKE vbak-audat, "Fecha Pedido
  29. netwr LIKE vbak-netwr, "Valor Pedido
  30. posnr LIKE vbap-posnr, "Linea de Pedido
  31. matnr LIKE vbap-matnr, "Cod.Articulo Linea
  32. arktx LIKE vbap-arktx, "Desc.Articulo Linea
  33. kbmeng LIKE vbap-kbmeng, "Cant.Articulo Linea
  34. netpr LIKE vbap-netpr, "Precio Articulo Linea
  35. END OF ty_detalle.
  36. *---------------------------------------------------------------------*
  37. * Tablas Internas y Registros (Workareas)
  38. *---------------------------------------------------------------------*
  39. DATA:
  40. ti_detalle TYPE STANDARD TABLE OF ty_detalle,
  41. wa_detalle LIKE LINE OF ti_detalle,
  42. wa_detalle_aux LIKE wa_detalle, " Auxiliar para corte Detalle
  43. so_ty_city(30) TYPE c,
  44. gv_t_ini TYPE i,
  45. gv_t_fin TYPE i,
  46. gv_records TYPE i,
  47. gv_mess(60) TYPE c,
  48. gv_time(12) TYPE c,
  49. gv_items(10) TYPE c,
  50. v_selected LIKE sy-tabix.
  51. *---------------------------------------------------------------------*
  52. * Variables de Acumulados de Corte
  53. *---------------------------------------------------------------------*
  54. DATA:
  55. gv_lineas_fra TYPE i, "Lineas en Pedido
  56. gv_bruto_fra TYPE p DECIMALS 2, "Bruto Pedido (cant x precio)
  57. gv_fras_cliente TYPE i, "Pedidos por Cliente
  58. gv_total_cliente TYPE p DECIMALS 2, "Importe Pedidos Cliente
  59. gv_fras_city TYPE i, "Pedidos por Ciudad
  60. gv_cli_city TYPE i, "Clientes por Ciudad
  61. gv_total_city TYPE p DECIMALS 2, "Importe Pedidos Ciudad
  62. gv_fras_pais TYPE i, "Pedidos por Pais
  63. gv_cli_pais TYPE i, "Clientes por Pais
  64. gv_total_pais TYPE p DECIMALS 2, "Importe Pedidos Pais
  65. gv_fras_total TYPE i, "Pedidos en Total
  66. gv_cli_total TYPE i, "Clientes en Total
  67. gv_gran_total TYPE p DECIMALS 2. "Importe Total Pedidos
  68. *---------------------------------------------------------------------*
  69. * Pantalla de selección
  70. *---------------------------------------------------------------------*
  71. SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-001.
  72. SELECT-OPTIONS so_pais FOR t005t-land1. "Seleccion Pais
  73. SELECT-OPTIONS so_cli FOR kna1-kunnr. "Seleccion Cod.Cliente
  74. SELECT-OPTIONS so_fecha FOR sy-datum. "Seleccion Fecha Pedido
  75. SELECT-OPTIONS so_city FOR (so_ty_city)
  76. DEFAULT 'A' TO 'ZZ'. "Seleccion Ciudad
  77. SELECTION-SCREEN END OF BLOCK b1.
  78. SELECTION-SCREEN BEGIN OF BLOCK b2 WITH FRAME TITLE text-002.
  79. PARAMETERS:
  80. p_all RADIOBUTTON GROUP grp1, "SELECT *
  81. p_field RADIOBUTTON GROUP grp1, "SELECT fields
  82. p_table RADIOBUTTON GROUP grp2, "... INTO TABLE
  83. p_loop RADIOBUTTON GROUP grp2. "SELECT ... ENDSELECT
  84. *SELECTION-SCREEN PUSHBUTTON 'Actualizar Opciones'.
  85. SELECTION-SCREEN END OF BLOCK b2.
  86. SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE text-003.
  87. PARAMETERS:
  88. p_jchl RADIOBUTTON GROUP grp3, "Pais->Cliente->Cabecera->Linea
  89. p_jlhc RADIOBUTTON GROUP grp3. "Linea->Cabecera->Cliente->Pais
  90. SELECTION-SCREEN END OF BLOCK b3.
  91. CLEAR:
  92. gv_lineas_fra,
  93. gv_bruto_fra,
  94. gv_fras_cliente,
  95. gv_total_cliente,
  96. gv_fras_city,
  97. gv_cli_city,
  98. gv_total_city,
  99. gv_fras_pais,
  100. gv_cli_pais,
  101. gv_total_pais,
  102. gv_fras_total,
  103. gv_cli_total,
  104. gv_t_ini,
  105. gv_t_fin,
  106. gv_t_ini,
  107. gv_t_fin,
  108. gv_records,
  109. gv_mess,
  110. gv_time,
  111. gv_gran_total.
  112. *-------------------------------------------------*
  113. START-OF-SELECTION.
  114. *-------------------------------------------------*
  115. * GET RUN TIME FIELD gv_t_ini.
  116. IF p_jlhc IS NOT INITIAL.
  117. IF p_table IS NOT INITIAL.
  118. IF p_all IS NOT INITIAL.
  119. GET RUN TIME FIELD gv_t_ini.
  120. SELECT *
  121. BYPASSING BUFFER
  122. INTO CORRESPONDING FIELDS OF TABLE ti_detalle
  123. FROM vbap AS l
  124. INNER JOIN vbak AS f
  125. ON l~vbeln = f~vbeln
  126. INNER JOIN kna1 AS c
  127. ON c~kunnr = f~kunnr
  128. INNER JOIN t005t AS p
  129. ON c~land1 = p~land1
  130. WHERE p~spras = sy-langu "Nombre de Pais en ES
  131. AND c~land1 IN so_pais
  132. AND c~ort01 IN so_city
  133. AND c~kunnr IN so_cli
  134. AND f~audat IN so_fecha.
  135. ENDIF.
  136. IF p_field IS NOT INITIAL.
  137. "Consulta de Lineas de Pedido
  138. "Lineas JOIN Cabeceras JOIN Clientes JOIN Paises
  139. GET RUN TIME FIELD gv_t_ini.
  140. SELECT c~land1 p~landx c~ort01 c~kunnr c~name1 f~vbeln
  141. f~audat f~netwr l~posnr l~matnr l~arktx l~kbmeng l~netpr
  142. BYPASSING BUFFER
  143. INTO CORRESPONDING FIELDS OF TABLE ti_detalle
  144. FROM vbap AS l
  145. INNER JOIN vbak AS f
  146. ON l~vbeln = f~vbeln
  147. INNER JOIN kna1 AS c
  148. ON c~kunnr = f~kunnr
  149. INNER JOIN t005t AS p
  150. ON c~land1 = p~land1
  151. WHERE p~spras = sy-langu "Nombre de Pais en ES
  152. AND c~land1 IN so_pais
  153. AND c~ort01 IN so_city
  154. AND c~kunnr IN so_cli
  155. AND f~audat IN so_fecha.
  156. ENDIF.
  157. ENDIF.
  158. IF p_loop IS NOT INITIAL.
  159. IF p_all IS NOT INITIAL.
  160. GET RUN TIME FIELD gv_t_ini.
  161. SELECT *
  162. BYPASSING BUFFER
  163. INTO CORRESPONDING FIELDS OF wa_detalle
  164. FROM vbap AS l
  165. INNER JOIN vbak AS f
  166. ON l~vbeln = f~vbeln
  167. INNER JOIN kna1 AS c
  168. ON c~kunnr = f~kunnr
  169. INNER JOIN t005t AS p
  170. ON c~land1 = p~land1
  171. WHERE p~spras = sy-langu "Nombre de Pais en ES
  172. AND c~land1 IN so_pais
  173. AND c~ort01 IN so_city
  174. AND c~kunnr IN so_cli
  175. AND f~audat IN so_fecha.
  176. APPEND wa_detalle TO ti_detalle.
  177. ENDSELECT.
  178. ENDIF.
  179. IF p_field IS NOT INITIAL.
  180. GET RUN TIME FIELD gv_t_ini.
  181. SELECT c~land1 p~landx c~ort01 c~kunnr c~name1 f~vbeln
  182. f~audat f~netwr l~posnr l~matnr l~arktx l~kbmeng l~netpr
  183. BYPASSING BUFFER
  184. INTO CORRESPONDING FIELDS OF wa_detalle
  185. FROM vbap AS l
  186. INNER JOIN vbak AS f
  187. ON l~vbeln = f~vbeln
  188. INNER JOIN kna1 AS c
  189. ON c~kunnr = f~kunnr
  190. INNER JOIN t005t AS p
  191. ON c~land1 = p~land1
  192. WHERE p~spras = sy-langu "Nombre de Pais en ES
  193. AND c~land1 IN so_pais
  194. AND c~ort01 IN so_city
  195. AND c~kunnr IN so_cli
  196. AND f~audat IN so_fecha.
  197. APPEND wa_detalle TO ti_detalle.
  198. ENDSELECT.
  199. ENDIF.
  200. ENDIF.
  201. ENDIF.
  202. IF p_jchl IS NOT INITIAL.
  203. IF p_table IS NOT INITIAL.
  204. IF p_all IS NOT INITIAL.
  205. GET RUN TIME FIELD gv_t_ini.
  206. SELECT *
  207. BYPASSING BUFFER
  208. INTO CORRESPONDING FIELDS OF TABLE ti_detalle
  209. FROM t005t AS p
  210. INNER JOIN kna1 AS c
  211. ON c~land1 = p~land1
  212. INNER JOIN vbak AS f
  213. ON c~kunnr = f~kunnr
  214. INNER JOIN vbap AS l
  215. ON l~vbeln = f~vbeln
  216. WHERE p~spras = sy-langu "Nombre de Pais en ES
  217. AND c~land1 IN so_pais
  218. AND c~ort01 IN so_city
  219. AND c~kunnr IN so_cli
  220. AND f~audat IN so_fecha.
  221. ENDIF.
  222. IF p_field IS NOT INITIAL.
  223. "Consulta de Lineas de Pedido
  224. "Lineas JOIN Cabeceras JOIN Clientes JOIN Paises
  225. GET RUN TIME FIELD gv_t_ini.
  226. SELECT c~land1 p~landx c~ort01 c~kunnr c~name1 f~vbeln
  227. f~audat f~netwr l~posnr l~matnr l~arktx l~kbmeng l~netpr
  228. BYPASSING BUFFER
  229. INTO CORRESPONDING FIELDS OF TABLE ti_detalle
  230. FROM t005t AS p
  231. INNER JOIN kna1 AS c
  232. ON c~land1 = p~land1
  233. INNER JOIN vbak AS f
  234. ON c~kunnr = f~kunnr
  235. INNER JOIN vbap AS l
  236. ON l~vbeln = f~vbeln
  237. WHERE p~spras = sy-langu "Nombre de Pais en ES
  238. AND c~land1 IN so_pais
  239. AND c~ort01 IN so_city
  240. AND c~kunnr IN so_cli
  241. AND f~audat IN so_fecha.
  242. ENDIF.
  243. ENDIF.
  244. IF p_loop IS NOT INITIAL.
  245. IF p_all IS NOT INITIAL.
  246. GET RUN TIME FIELD gv_t_ini.
  247. SELECT *
  248. BYPASSING BUFFER
  249. INTO CORRESPONDING FIELDS OF wa_detalle
  250. FROM t005t AS p
  251. INNER JOIN kna1 AS c
  252. ON c~land1 = p~land1
  253. INNER JOIN vbak AS f
  254. ON c~kunnr = f~kunnr
  255. INNER JOIN vbap AS l
  256. ON l~vbeln = f~vbeln
  257. WHERE p~spras = sy-langu "Nombre de Pais en ES
  258. AND c~land1 IN so_pais
  259. AND c~ort01 IN so_city
  260. AND c~kunnr IN so_cli
  261. AND f~audat IN so_fecha.
  262. APPEND wa_detalle TO ti_detalle.
  263. ENDSELECT.
  264. ENDIF.
  265. IF p_field IS NOT INITIAL.
  266. GET RUN TIME FIELD gv_t_ini.
  267. SELECT c~land1 p~landx c~ort01 c~kunnr c~name1 f~vbeln
  268. f~audat f~netwr l~posnr l~matnr l~arktx l~kbmeng l~netpr
  269. BYPASSING BUFFER
  270. INTO CORRESPONDING FIELDS OF wa_detalle
  271. FROM t005t AS p
  272. INNER JOIN kna1 AS c
  273. ON c~land1 = p~land1
  274. INNER JOIN vbak AS f
  275. ON c~kunnr = f~kunnr
  276. INNER JOIN vbap AS l
  277. ON l~vbeln = f~vbeln
  278. WHERE p~spras = sy-langu "Nombre de Pais en ES
  279. AND c~land1 IN so_pais
  280. AND c~ort01 IN so_city
  281. AND c~kunnr IN so_cli
  282. AND f~audat IN so_fecha.
  283. APPEND wa_detalle TO ti_detalle.
  284. ENDSELECT.
  285. ENDIF.
  286. ENDIF.
  287. ENDIF.
  288. DESCRIBE TABLE ti_detalle LINES gv_records.
  289. * Tiempo de ejecucion
  290. GET RUN TIME FIELD gv_t_fin.
  291. gv_t_ini = gv_t_fin - gv_t_ini.
  292. WRITE gv_t_ini TO gv_time.
  293. WRITE gv_records TO gv_items.
  294. CONCATENATE gv_items 'resultados en' gv_time 'microsegundos.'
  295. INTO gv_mess
  296. SEPARATED BY ' '.
  297. MESSAGE gv_mess TYPE 'S'.
  298. *-------------------------------------------------*
  299. END-OF-SELECTION.
  300. *-------------------------------------------------*

 

 

 


Sobre el autor

Publicación académica de Carlos Piles Rosell, en su ámbito de estudios para la Carrera Consultor ABAP.

SAP Senior

Carlos Piles Rosell

Profesión: Analista de Sistemas y Programador - España - Legajo: GZ57B

✒️Autor de: 24 Publicaciones Académicas

🎓Egresado de los módulos:

Disponibilidad Laboral: PartTime

Certificación Académica de Carlos Piles

✒️+Comunidad Académica CVOSOFT

Continúe aprendiendo sobre el tema "La performance en ABAP" de la mano de nuestros alumnos.

SAP Master

PERFORMANCE EN PROGRAMACION ABAP El performance de un programa es el analisis del desempeño y rendimiento de un programa, para esto se va a trabajar con una herramiento de SAP estandar que es sumamente util para el analisis de la performance, esta es la transacción SE30. El objetivo del performance es poder realizar programas de alta calidad, que funcionen perfectamente en el ambiente productivo, que es donde las tablas de las bases de datos contienen millones de registros y cada micro segundo cuenta. Los tiempos de procesamiento de ABAP se dividen en tres: La base de datos, Abap y el sistema, de estos 3 item debemos tomar en cuenta en cuanto a la performance es la base de datos ya que este es el que mas recursos consumen y...

Acceder a esta publicación

Creado y Compartido por: Jesus Enrique Ramos Bello / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Senior

En ABAP existen las buenas y malas practicas porque afectan a la performance de los programas o a la reutilización del código. Performance de los programas Performance: Analisís del desempeño y el rendimiento del programa. - Usaremos la transax. SE30 - presionamos el boton Tips & Tricks - Analizaremos las diferentes prácticas de la programación ABAP - En 2 paneles se compararán fragmentos de código. Los tiempos de procesamiento de un programa ABAP se dividen en 3: ABAP, BD y Sistema. De estos tres items el que debemos tener en cuenta principalmente cuando evaluamos la performance es el tiempo de la BD ya que este es el que mas recursos consumen y por consiguiente es el que mas...

Acceder a esta publicación

Creado y Compartido por: Jesus German Cavazos Elizondo

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

SAP Senior

Performance en abap presionamos el boton trips & tricks y podremos ver carpetas que contienen codigos donde prodremos comparar el performance de ambos codigos. a si podremos saber cuales son las mejores practicas de codigicacion.

Acceder a esta publicación

Creado y Compartido por: Luis Eugenio Leyva Orozco

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

SAP Senior

Performance en ABAP En ABAP existen buenas y malas practicas sea por que afectan a los Performance de los programas o por que afectan a otros factores determinantes como es la utilización de código. Performance de los programas - se trata del análisis del desempeño y rendimiento del programa. Utilizamos la transacción SE30 para ver las Performance. Una vez dentro pulsamos el botón Tips & Tricks. Abrimos la carpeta SQL Interface y seleccionamos Select aggregates. Vamos a ver dos códigos distintos que dan el mismo resultado. Para evaluar la performance pulsamos el botón Medir tiempo ejecución. Hacemos lo mismo con Select with select list. Aquí podemos ver que especificando...

Acceder a esta publicación

Creado y Compartido por: Ana Schiau

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

SAP Senior

VIDEO - PERFORMANCE EN ABAP Performance en ABAP El objetivo de esta lección es tener bien claro que prácticas son desaconsejadas y cuales si son recomendadas, de modo de poder apuntar a realizar programas de alta calidad, que funcionen perfectamente en el ambiente productivo, donde las tablas de la BD contienen millones de registros y cada micro segundo cuenta. Los tiempos de procesamiento de un programa ABAP se divide entre ABAP, la BD y el Sistema, de estos tres items el q debemos tener en cuenta principalmente cdo evaluamos la performance es el tiempo de la BD ya q esté es el q más recurso consume y por consiguiente es el q más tiempo requiere, cdo más alto sea el porcentaje del procesamiento de...

Acceder a esta publicación

Creado y Compartido por: Mayra Maria Pino Rodriguez

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

SAP Master

Cuando Hablamos de performance nos referimos al desempeño del programa, para poder analizar la performance podemos utilizar la transacción SE30 por el botón TIPS & TRICKS donde nos orienta con cuales de las sentencia que son aconsejables utilzar. Los tiempos de procesamiento de un programa ABAP se dividen en tres: ABAP ,la base de datos y el sistema, de los tres el que mas consume recursos es el de la base de datos y es con el que tenemos tener mas cuidado.

Acceder a esta publicación

Creado y Compartido por: William Alejandro Lemus

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

SAP Senior

Performance en ABAP Para verificar el performance ingresamos a la TX SE30, Aqui presionamos Tips & Tricks en la cual nos recomiendan buenas practicas, nos daran los puntos en el cual podemos programar en ABAP de diferentes manera, y ver su performance, y podemos ver el el tipo de ejecucion. Tiempos de procesamiento se dividen en 3: ABAP: Debe ser lo más ALTO posible BBDD: Debe ser lo más BAJO posible. A tener en cuenta para la performance ya que es lo que más tpo requiere. SISTEMA:

Acceder a esta publicación

Creado y Compartido por: Ruben Dario Martucci / Disponibilidad Laboral: FullTime

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

SAP Senior

lección 8/9: Video - Performance en ABAP Accedemos a la transacción SE30 clicamos en el botón tips & tricks acáveremos carpetas que contienen archivos con código de consultas en SQL que podremos comparar la performance de ambos códigos (el resultado nos indicara en microsegundos), por sentido comun sabremos que el que tarda menos tiempo en ejecutarse sera el de mayor performance, de tal manera podremos saber cuál es la mejor práctica para desarrollar.

Acceder a esta publicación

Creado y Compartido por: Ruben Santiago Cuenca Balanza / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Expert


PERFORMANCE EN ABAP – LECCION 7-8 PERFORMANCE, cuando hablamos de performance nos referimos al análisis de desempeño de un programa o transacción, para medir la performance de un programa o transacción realizaremos pruebas de rendimiento NOTA, los tiempos de procesamientos de un programa ABAP, se dividen entre ABAP, la base de dato y el sistema, de estos tres ítems el que debemos tener en cuenta principalmente cuando evaluamos la performance, es el tiempo de la base de dato ya que es el que más recursos consume y por consiguiente es el que más tiempo requiere, cuanto más alto sea el porcentaje del procesamiento de la base de dato en comparación a los otros dos porcentajes,...

Acceder a esta publicación

Creado y Compartido por: Cristian Darwin Arteaga Diaz / Disponibilidad Laboral: FullTime + Carta Presentación

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

SAP Expert


Performance en ABAP Se refiere al rendimiento de cualquier programa ABAP y en está lección nos explican a evaluarlo mediante la transacción SE30-siendo ésta una transacción antigua, ahora reemplazada por la transacción SAT que tiene más funcionalidades-además existen otras herramientas para poder evaluar la performance ABAP como el code inspector, ST05, ST12. La idea para mejorar la performance de nuestros programas ABAP es reducir el número de accesos a la base de datos.

Acceder a esta publicación

Creado y Compartido por: José Luis Zevallos Mamani

 


 

👌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!